在java中,一个数左移n位,就是将这个数乘以2的n次方,右移就是将这个数除以2的n次方怎么理解?
把这个数二进制化就能理解了.如十进制的2,二进制表示是0010,2左移3位,就是在二进制的低位补3个0,然后变成00010000,转成十进制就是16,即2*2^3,右移大体一致,需要分两种情况。
右移的话要分带符号位和不带符号位两种。 计算机中的数都是二进制表示的,以8位的byte类型表示为例,5可以表示为:00000101(最高位表示符号,0位正,1为负) 无论>>还是>>>都是针对二进制数进行操作的。 1、右移运算符>>使指定值的所有位都右移规定的次数。右边移出去的部分扔掉不要,左边空出来的部分用原来的数字填充(这就是所谓的带符号右移) ——比如说5,右移一位后为00000010。
假设x=-12,表示为32位int型就是 11111111111111111111111111110100 x>>3即带符号右移3位,结果是 11111111111111111111111111111101,化为十进制等于-3。 2、>>>与>>唯一的不同是它无论原来的最左边是什么数,统统都用0填充。 byte是8位的,-1表示为byte型是11111111(补码表示法) b>>>4就是无符号右移4位,即00001111,这样结果就是15。