Java移位运算符问题

Java移位运算符问题请问这个题怎么做?
无符号右移对正数和负数有什么区别?
左移有没有带符号和无符号之分??
谢谢

有符号右移会保留最高位的符号位,从次高位开始逐位右移填0;而无符号右移会将符号位一起右移,并将高位全部填0。
例:对于一个byte类型的数10010100来说,有符号右移2位变为10000101,而无符号右移2位变为00100101。前者仍然是一个负数,而后者变成了正数。
左移只有有符号的,没有无符号左移。
温馨提示:内容为网友见解,仅供参考
第1个回答  2020-03-21
  学习Java本来就是一件日积月累的事情,或许你通过自学能掌握一些皮毛技术,通过Java学习机构学到Java的一些基本大面,但想要做到精通,还是需要自己技术的日积月累和工作经验的不断积累。

  今天给大家分享的技术知识是:Java中的位移运算符!
  1) “有符号”左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补0)。
  左移移位相当于乘以2,例如
  3 << 2 //12 则是将数字3左移2位 3*2*2 = 3*(2的2次方)
  分析:首先把3转换为二进制数字0000 0000 0000 0000 0000 0000 0000 0011,然后把该数字高位(左侧)的两个零移出,其他的数字都朝左平移2位,最后在低位(右侧)的两个空位补零。则得到的最终结果是0000 0000 0000 0000 0000 0000 0000 1100,则转换为十进制是12.数学意义:
  在数字没有溢出的前提下,对于正数和负数,左移一位都相当于乘以2的1次方,左移n位就相当于乘以2的n次方。
  2) “有符号”右移位运算符(>>)则将运算符左边的运算对象向右移动运算符右侧指定的位数。 “有符号”右移位运算符使用了“符号扩展”:若值为正,则在高位插入0;若值为负,则在高位插入1。
  >>运算规则:按二进制形式把所有的数字向右移动对应位数,低位移出(舍弃),高位的空位补符号位,移位后得到的数字为正数则补0,负数补1。
  例如11 >> 2,则是将数字11右移2位
  分析:11的二进制形式为:0000 0000 0000 0000 0000 0000 0000 1011,然后把低位的最后两个数字移出,因为该数字是正数,所以在高位补零。则得到的最终结果是0000 0000 0000 0000 0000 0000 0000 0010.转换为十进制是3.数学意义:右移一位相当于除2,右移n位相当于除以2的n次方。
  3) Java也添加了一种“无符号”右移位运算符(>>>),它使用了“零扩展”:无论正负,都在高位插入0
  4)右移一位相当于除以2,左移一位(在不溢出的情况下)相当于乘以2;移位运算速度高于乘除运算。
  5)位运算符的优先级
  ~的优先级最高,其次是<<、>>和>>>,再次是&,然后是^,优先级最低的是|。
第2个回答  2018-06-12
理解本质才是关键,不管有符号还是无符号,不管正数还是负数,都是一样的原理,正负数在计算机里存的都是补码。移位的时候并不关心什么符号位,只有如下规则:
32位补码移的位数超过32时,取其对32的余数来进行移位;
32位补码左移时,移出去的bit直接去掉,右边补相应位数的0;
32位补码右移时,移出去的bit也是直接去掉,但是左边补相应倍数的1还是0得根据原来最高bit位来看,如果最高位bit位是0则补0,是1则补1。
剩下的32位的最高位,是0就是正数,是1就是负数,当然uint32不管怎么移就是正的了。不过不管是正是负,终究还是看最终你用的类型,因为有无符号类型是可以强制转换的。
其实可以发现,补码右移的补位规则就是为了保证正负数右移不变符号。
而补码左移补位规则,在有溢出的情况下,正负号是可能会变的,但是至少能保证在不溢出情况下,正负不会变。本回答被提问者和网友采纳

java中的移位问题 程序如下
我们知道,在java中,int是占4个字节的,也就是32位。这个程序,应该是为了将一个int类型转换成32位2进制数。原理:1. <<:左移运算符,在没有数字溢出的情况下,左移一位都相当于乘以2的1次方,左移n位就相当于乘以2的n次方。2. &:位运算符,当两边操作数的位同时为1时,结果为1,否则...

Java中,–128>>4等于多少,怎么算的
在JAVA中,>>是移位运算符,4表示向右位移4位,–128转为二进制是-10000000,向右移动4位就是-1000(二进制),转回即为-8。

java位移运算符
今天给大家分享的技术知识是:Java中的位移运算符!1) “有符号”左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补0)。左移移位相当于乘以2,例如 3 << 2 \/\/12 则是将数字3左移2位 3*2*2 = 3*(2的2次方)分析:首先把3转换为二进制数字0000 0000 0000 ...

JAVA面试题,请问这两个(-2>>2 ,2<<2)的值分别是什么?为什么。谢谢_百度...
这是移位的计算啊,这是最接近计算机硬件的计算操作。首先要把2转化为二进制的表示形式00000010,然后再左移两位变成00001000,转换为十进制就是8。移位运算符就是在二进制的基础上对数字进行平移。按照平移的方向和填充数字的规则分为三种:<<(左移)、>>(带符号右移)和>>>(无符号右移)。三种...

Java,a>>b是什么意思?
<< 和>>是java中的移位运算符,<<是左移位,>>是右移位,因为数据存储是二进制的所以左移1相当于乘以2的1次方,右移相当于乘以2的-1次方,例如 << : 左移运算符,num << 1,相当于num乘以2,num << 2,相当于num乘以2再乘以2 >> : 右移运算符,num >> 1,相当于num除以...

java 运算符问题
你好,<<相当于乘以2 <<24相当于*2执行24次 你可以把以下代码运行下就知道了 public class test { public static void main(String[] args) { int size = 2 << 24;System.out.println(size);int i = 2;for (int j = 0; j < 24; j++) { i *= 2;} System.out.println(i);}...

java中“<<”是什么啊!例如2 << 3=8是怎么算的啊!
<<是左移运算符,value<<num是指把value左移num位。每左移一位,最高位被移出,并且用0填充右边。在对byte和short类型的值左移时会自动扩展为int型。每次左移都相当于使操作数翻倍,可以通过这种方法来进行快速乘2的运算。2<<3就是2左移3次,也就是2乘以2的三次方,结果应该是16。

java中:-4<<2怎么算的。 -4321>>>30这题有什么简单算法没有?_百度知 ...
低位移出(舍弃),高位的空位补零。对于正数来说和带符号右移相同,对于负数来说不同。其他结构和>>相似。小结 二进制运算符,包括位运算符和移位运算符,使程序员可以在二进制基础上操作数字,可以更有效的进行运算,并且可以以二进制的形式存储和转换数据,是实现网络协议解析以及加密等算法的基础。

Java中的位移运算中的>>(逻辑右移)和>>>(算术右移)的区别?
逻辑右移是将各位依次右移指定位数,然后在左侧补0,算术右移是将各位依次右移指定位数,然后在左侧用原符号位补齐

Java中,位运算符>>,右移时左边何时补0,何
举个例子:2左移动3位 2(十进制)=00000010(二进制)二进制00000010向左移动三位变成了00010,超出了8位,相当于删除前三个字符位,删除之后又由于不满足8位,后面填0,变成00010000 00010000(二进制) = 16(十进制)

相似回答