Khnaone 2021-04-01 19:01 采纳率: 33.3%
浏览 39
已采纳

Java中的移位运算

这是我今天看到的关于移位运算的帖子,然后有了一点想法。

对于一个byte类型的变量a,a = 5 ,它的二进制补码为00000101,按照这个想法,逻辑右移一位的结果为00000010,正数的反码、补码、原码都一样,它的结果应该为2。
同一个变量,进行同样的初始化操作,算数右移一位,结果应该为10000010,也就是说,算数右移一位,这个数从正数变成了负数,结果为-2。
我不明白,为什么右移操作会连符号位一起改变,还有一点,就是,为什么移位操作会比乘除法更快捷?因为我要计算它的原码,对于负数,我还要计算反码和补码。

 

  • 写回答

3条回答 默认 最新

  • CSDN专家-三岁丫 2021-04-01 20:04
    关注

    这个多个问题,我一个一个给你说吧

    1. 为什么右移操作会连符号为一起改变,

    这个嘛,确实不知道呢,毕竟别人这么设计,可能有很多考虑在里面吧,但是不知我这种渣渣能知道了的

    2. 移位操作比乘除快

    是因为对计算来说移位很简单,而如果要完成的一次乘除的话,可能需要更多的计算。具体为啥,可能你需要了解一下底层这么实现加减乘除的。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算