已知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无用
悬赏问题
- ¥170 如图所示配置eNSP
- ¥20 docker里部署springboot项目,访问不到扬声器
- ¥15 netty整合springboot之后自动重连失效
- ¥15 悬赏!微信开发者工具报错,求帮改
- ¥20 wireshark抓不到vlan
- ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
- ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
- ¥15 stata安慰剂检验作图但是真实值不出现在图上
- ¥15 c程序不知道为什么得不到结果
- ¥15 键盘指令混乱情况下的启动盘系统重装