位运算 - 位运算基本操作
package com.bitOperation;/*** java的整数是有符号的,二进制表示的时候,第一位是符号位* 其范围是 -2^31 ~ 2^31-1** Java的设计,负数在内存中存储的值,拿出来使用的时候,需要部分取反(符号位不动)再+1,为什么?* 为了让 +,-,*,/ 等看似不同的操作,在底层使用相同的处理。*/ public class IntegerTo32Bit {//将整形数值的32位二进制数,打印出来public void to32bit(Integer value){for(int i=31; i>=0; i--){//符号位也一样,是1的话,按位与之后还是1; 是0的话,按位与还是0System.out.print((value & (1 << i)) == 0 ? '0' : '1');}System.out.println("");}public static void main(String [] args){IntegerTo32Bit integerTo32Bit = new IntegerTo32Bit();int testNum = 10;integerTo32Bit.to32bit(testNum); // 00000000000000000000000000001010//最大值 2^31 - 1System.out.println("最大值");int a = Integer.MAX_VALUE;integerTo32Bit.to32bit(a); // 01111111111111111111111111111111System.out.println("");//最小值 -2^31System.out.println("最小值");int b = Integer.MIN_VALUE;integerTo32Bit.to32bit(b); // 10000000000000000000000000000000, 这是内存中的存储值,具体代表的数值为 -- 除符号位,其它位取反后 + 1System.out.println("");//左移System.out.println("左移");integerTo32Bit.to32bit(1); // 00000000000000000000000000000001integerTo32Bit.to32bit(1 << 1); // 00000000000000000000000000000010integerTo32Bit.to32bit(1 << 2); // 00000000000000000000000000000100integerTo32Bit.to32bit(1 << 3); // 00000000000000000000000000001000integerTo32Bit.to32bit(-1); // 11111111111111111111111111111111integerTo32Bit.to32bit(-1 << 1);// 11111111111111111111111111111110integerTo32Bit.to32bit(-1 << 2);// 11111111111111111111111111111100integerTo32Bit.to32bit(-1 << 3);// 11111111111111111111111111111000int minValue = Integer.MIN_VALUE;System.out.println("最小值左移");integerTo32Bit.to32bit(minValue << 1); // 00000000000000000000000000000000//错误,没有所谓的带符号左移,只有带符号右移 // integerTo32Bit.to32bit(minValue <<< 1);System.out.println(minValue); // -2147483648System.out.println(minValue << 1); // 0System.out.println("");//右移System.out.println("最小值右移");int m = Integer.MIN_VALUE;integerTo32Bit.to32bit(m >> 1); // 11000000000000000000000000000000, 带符号右移integerTo32Bit.to32bit(m >> 2); // 11100000000000000000000000000000, 带符号右移integerTo32Bit.to32bit(m >>> 1); // 01000000000000000000000000000000, 不带符号右移integerTo32Bit.to32bit(m >>> 2); // 00100000000000000000000000000000, 不带符号右移System.out.println("");//负数System.out.println("负数");integerTo32Bit.to32bit(-1); // 11111111111111111111111111111111, 这是内存中的存储值,具体代表的数值为 -- 除符号位,其它位取反后 + 1integerTo32Bit.to32bit(-5); // 11111111111111111111111111111011, 这是内存中的存储值,具体代表的数值为 -- 除符号位,其它位取反后 + 1System.out.println("");//自己玩, 各种位运算System.out.println("按位操作");int x = 12319876;int y = 3829876;integerTo32Bit.to32bit(x); // 00000000101110111111110010000100integerTo32Bit.to32bit(y); // 00000000001110100111000001110100System.out.println("============");integerTo32Bit.to32bit(x | y); // 00000000101110111111110011110100, 按位或integerTo32Bit.to32bit(x & y); // 00000000001110100111000000000100, 按位与integerTo32Bit.to32bit(x ^ y); // 00000000100000011000110011110000 , 按位异或,就是不一样的时候,结果才是1,一样的话是0, 相同为0,不同为1System.out.println("");//取反//整数取反之后,其最高位变为1,表示负数。同理,负数取反之后,变为正数System.out.println("取反");int c = -1;integerTo32Bit.to32bit(-1); // 11111111111111111111111111111111integerTo32Bit.to32bit(~c); // 00000000000000000000000000000000} }
位运算 - 位运算基本操作相关推荐
- BMP格式知识之二:16位,24位,32位的BMP图片算法是如何运算的
BMP格式知识之二:16位,24位,32位的BMP图片算法是如何运算的 原文:http://blog.csdn.net/qq445803843/article/details/46476433 这段代 ...
- 常用技巧 —— 位运算 —— 位运算基础
[与运算] 与运算常用于二进制的取位操作,其用符号 & 表示,相同位的两个数字都为1,则为1,若有一个不为1,则为0. 例如:00101 & 11100 = 00100 其会将两个十进 ...
- 使用位运算(与运算)代替%操作
使用位运算(&与运算)代替%操作 %运算为取余运算 由于我们知道位运算比较高效,在某些情况下,当b为2的n次方时,有如下替换公式: a % b = a & (b-1)(b=2^n) 即 ...
- Home_W的位运算(位运算+预处理)
Home_W的位运算1 题目链接: 传送门解题思路:这题有两种解题思路,一种就是\(n^2\times m\)的时间复杂度,还有一种就是经过预处理的时间复杂度为\(n^2\)的方法,先说第一种,大家直 ...
- 关于库位“参与MRP运算”与“不参与运算”相互变动的注意事项
一.现状 因实际业务需求,库存从"不参与MRP运算"调整为"不参与运算",反之亦然. 二.原理 1.库位是否参与MRP运算 设置库位是否参与MRP运算, ...
- 设变量n为float类型,m为int类型,则以下能实现将n中的数值保留小数点后两位,第三位进行四舍五人运算的表达式是: A) n=(n*100+0.5)/100.0 B)m=n*100+0.5
设变量n为float类型,m为int类型,则以下能实现将n中的数值保留小数点后两位,第三位进行四舍五人运算的表达式是: A) n=(n100+0.5)/100.0 B)m=n100+0.5 ,n= m ...
- 【FPGA】定点数 数据位宽 运算 位宽截取
在FPGA中,经常使用定点数表示小数,在进行各种运算时,定点数的位宽会发生变化,并且需要在适当地时候对数据的位宽进行截取. 运算要求和引起的位宽变化 假设存在两个数A.B,假定A位宽为m,小数位宽为a ...
- java符号位_java 位运算符号
<道生一,一生二,二生三,三生万物>出自老子的<道德经>第四十二章.主要讲述了一.二.三这几个数字,并不把一.二.三看作具体的事物和具体数量.它们只是表示"道&quo ...
- java用流体加减乘除_任意输入两个数,完成加法、减法、乘法、除法运算!(加减乘除运算分别定义四个方法)_学小易找答案...
[简答题]编写程序实现菜单设计 [简答题]一层平面图 [简答题]编写一个程序实现大小写字母转换 [简答题]利用循环语句输出一个五行的等腰三角形,如下图 [简答题]编写一个程序实现交换两个变量的数值. ...
- 2 计算机组成原理第二章 数据的表示和运算 定点数运算 浮点数运算
文章目录 1 进制转换 2 定点数表示及其运算 2.1 定点数表示 2.1.1 真值→补码 2.1.2 补码→真值 2.1.3 [XT]补 →[-XT]补 2.1.4 真值.原码.反码.补码转换关系图 ...
最新文章
- 不存在从node到node*的适当转换函数_C++中参数需要类型转换,请不要用成员函数...
- IOS设计模式学习(1)设计模式初窥
- Android:页面跳转传参方式一,页面跳转传参方式二
- python基本随机生成函数_Python学习笔记(三):随机生成函数方法
- iOS 利用长按手势移动 Table View Cells
- 嵌入式操作系统内核原理和开发(任务创建和堆栈溢出检查)
- android布局时长分析,Android性能优化:布局优化 详细解析(含、、讲解 )
- 剔除List中的重复值
- Mysql的key_len计算方法
- 2020低压电工模拟考试及低压电工复审模拟考试
- 牛客网-前端刷题记录(简单级)
- 对抗攻击常见方法汇总
- mongodb用户权限修改,删除以及robomongo显示问题
- ecshop 2.7.2安装
- 从阿里巴巴发行价看A股新股投资机会
- 33岁想从头学做网页设计_从头到头的10位客户我如何设计和推出saas产品
- 互联网医疗行业PEST分析实践
- openstack 【T版】(五)——部署nova组件
- 欧盟电子雾化器检测及合规要求
- 自定义Gradle插件之Hello World