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}
}

位运算 - 位运算基本操作相关推荐

  1. BMP格式知识之二:16位,24位,32位的BMP图片算法是如何运算的

    BMP格式知识之二:16位,24位,32位的BMP图片算法是如何运算的 原文:http://blog.csdn.net/qq445803843/article/details/46476433 这段代 ...

  2. 常用技巧 —— 位运算 —— 位运算基础

    [与运算] 与运算常用于二进制的取位操作,其用符号 & 表示,相同位的两个数字都为1,则为1,若有一个不为1,则为0. 例如:00101 & 11100 = 00100 其会将两个十进 ...

  3. 使用位运算(与运算)代替%操作

    使用位运算(&与运算)代替%操作 %运算为取余运算 由于我们知道位运算比较高效,在某些情况下,当b为2的n次方时,有如下替换公式: a % b = a & (b-1)(b=2^n) 即 ...

  4. Home_W的位运算(位运算+预处理)

    Home_W的位运算1 题目链接: 传送门解题思路:这题有两种解题思路,一种就是\(n^2\times m\)的时间复杂度,还有一种就是经过预处理的时间复杂度为\(n^2\)的方法,先说第一种,大家直 ...

  5. 关于库位“参与MRP运算”与“不参与运算”相互变动的注意事项

        一.现状 因实际业务需求,库存从"不参与MRP运算"调整为"不参与运算",反之亦然. 二.原理 1.库位是否参与MRP运算 设置库位是否参与MRP运算, ...

  6. 设变量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 ...

  7. 【FPGA】定点数 数据位宽 运算 位宽截取

    在FPGA中,经常使用定点数表示小数,在进行各种运算时,定点数的位宽会发生变化,并且需要在适当地时候对数据的位宽进行截取. 运算要求和引起的位宽变化 假设存在两个数A.B,假定A位宽为m,小数位宽为a ...

  8. java符号位_java 位运算符号

    <道生一,一生二,二生三,三生万物>出自老子的<道德经>第四十二章.主要讲述了一.二.三这几个数字,并不把一.二.三看作具体的事物和具体数量.它们只是表示"道&quo ...

  9. java用流体加减乘除_任意输入两个数,完成加法、减法、乘法、除法运算!(加减乘除运算分别定义四个方法)_学小易找答案...

    [简答题]编写程序实现菜单设计 [简答题]一层平面图 [简答题]编写一个程序实现大小写字母转换 [简答题]利用循环语句输出一个五行的等腰三角形,如下图 [简答题]编写一个程序实现交换两个变量的数值. ...

  10. 2 计算机组成原理第二章 数据的表示和运算 定点数运算 浮点数运算

    文章目录 1 进制转换 2 定点数表示及其运算 2.1 定点数表示 2.1.1 真值→补码 2.1.2 补码→真值 2.1.3 [XT]补 →[-XT]补 2.1.4 真值.原码.反码.补码转换关系图 ...

最新文章

  1. 不存在从node到node*的适当转换函数_C++中参数需要类型转换,请不要用成员函数...
  2. IOS设计模式学习(1)设计模式初窥
  3. Android:页面跳转传参方式一,页面跳转传参方式二
  4. python基本随机生成函数_Python学习笔记(三):随机生成函数方法
  5. iOS 利用长按手势移动 Table View Cells
  6. 嵌入式操作系统内核原理和开发(任务创建和堆栈溢出检查)
  7. android布局时长分析,Android性能优化:布局优化 详细解析(含、、讲解 )
  8. 剔除List中的重复值
  9. Mysql的key_len计算方法
  10. 2020低压电工模拟考试及低压电工复审模拟考试
  11. 牛客网-前端刷题记录(简单级)
  12. 对抗攻击常见方法汇总
  13. mongodb用户权限修改,删除以及robomongo显示问题
  14. ecshop 2.7.2安装
  15. 从阿里巴巴发行价看A股新股投资机会
  16. 33岁想从头学做网页设计_从头到头的10位客户我如何设计和推出saas产品
  17. 互联网医疗行业PEST分析实践
  18. openstack 【T版】(五)——部署nova组件
  19. 欧盟电子雾化器检测及合规要求
  20. 自定义Gradle插件之Hello World

热门文章

  1. 2015年数据结构第五题(输出二叉树的最长一枝)(C/C++)
  2. java-EasyExcel导出excel设置单元格为文本格式(含代码)
  3. 微信辅助验证 信息填写正确 却提示绑卡信息错误的解决办法
  4. Java Overview
  5. 逆向破解--除去软件nag窗口
  6. 张艾迪Eidyzhang:解码天才Eidyzhang的诞生
  7. 中国56民族 sql
  8. ros操作命令与实操-话题发布
  9. 如何用手机快速制作好看的二维码
  10. 计算机的未来发展趋势