已知a=-18,请计算右移2位、左移2位和无符号右移2位后的值,并用程序自行验证。
2条回答 默认 最新
- a5156520 2023-03-11 08:53关注
假设a为int类型,则:
-18右移2位为:-5
-18左移2位为:-72
-18无符号右移2位为:1073741819
a=-18, 它对应的二进制位为: 1111 1111 1111 1111 1111 1111 1110 1110
右移运算符>>是将操作数所有二进制位向 右 移动指定位数,左边的空位根据原数的符号位补0或者1(原数为负数补1,正数则补0),右边移走的部分去除.
所以a>>2 的结果就是: 1111 1111 1111 1111 1111 1111 1111 1011。(去除低位的10,高位补上11),它对应的int类型整数是:-5。
左移移运算符<<是将操作数所有二进制位向 左 移动指定位数,右边的空位补0,左边移走的位去除.
所以a<<2 的结果就是: 1111 1111 1111 1111 1111 1111 1011 1000。(去除高位的11,低位补上00),它对应的int类型整数是:-72。
无符号右移>>>是将操作数所有二进制位向 右 移动指定的位数,左边的空位补0(不考虑原数正负),右边移走的部分去除。
所以a>>>2的结果是:0011 1111 1111 1111 1111 1111 1111 1011 。(去除低位的10,高位补上00),它对应的int类型整数是:1073741819。
测试代码如下:
参考资料:
Java基础入门(清华大学出版社)- 第2章 Java编程基础 - 2.3 Java中的运算符 - 2.3.5 位运算符 (第37页,38页)https://www.cnblogs.com/blog-cq/p/5793529.htmlpublic class GressionTest { public static void main(String[] args) { // TODO Auto-generated method stub int a = -18; System.out.println(a+"右移2位为:"+(a>>2)); System.out.println(a+"左移2位为:"+(a<<2)); System.out.println(a+"无符号右移2位为:"+(a>>>2)); } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥20 机器学习能否像多层线性模型一样处理嵌套数据
- ¥20 西门子S7-Graph,S7-300,梯形图
- ¥50 用易语言http 访问不了网页
- ¥50 safari浏览器fetch提交数据后数据丢失问题
- ¥15 matlab不知道怎么改,求解答!!
- ¥15 永磁直线电机的电流环pi调不出来
- ¥15 用stata实现聚类的代码
- ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
- ¥20 docker里部署springboot项目,访问不到扬声器
- ¥15 netty整合springboot之后自动重连失效