java的<<左移,>>右移,>>>无符号右移

>>右移

  右移,道在二进制中,假设用一个32位的Int表示一个64,那么高位就都是0,所以当我们把整个二进制数右移,如0100000 >> 2 = 0001000,可以看到右移两位后的数变成了8,可以分析出其实右移就是一个除以2的操作

例:对于非2,4,8,16,64的数也可以试验一下:

System.out.println(3 >> 1);
System.out.println(5 >> 1);
System.out.println(63 >> 1);

其结果分别为1,2,31.

所以右移就是一个整除2的过程,右移一位就是除一次,n位就是除n次。

同时需要注意的>>是带符号的,也就是说它的高位补充数是由最高位来决定的,正数的最高位为0,负数的最高位为1,所以负数 >>后还是负数。

另例:

        System.out.println(5>>1);
        System.out.println(63>>1);
        System.out.println(63>>2);
        System.out.println(63>>3);

结果:

2
31
15
7

可以看出>>1则除以2,>>2则除以2在除以2.后面以此类推

>>>无符号右移

原理和上面一样,不同的是它的高位总是由0来补充。

        System.out.println(3 >>> 1);
        System.out.println(5 >>> 1);
        System.out.println(64 >>> 1);
        System.out.println(63 >>> 1);
        System.out.println(-63 >>> 1);

结果分别是:

1
2
32
31
2147483616

由此可看出>>>符号在计算正数时与>>符号一样,而如果为负数时则移动位置变化

因为-64在计算机中的存在为:11111111111111111111111111000000,那么无符号右移一位就变成了01111111111111111111111111100000,这个值等于2147483616

所以对于这些位运算不要用惯性思维去思考,一定要想明白二进制是如何工作的。

<<左移

 System.out.println(-64 << 1);
  System.out.println(64 << 1);
  System.out.println(25 << 1);

结果是-128,128,50,显然是乘2的

左移后低位是由0来补充的

3<<3    表示3乘2的三次方

因为将一个数左移n位,就相当于乘以了2的n次方

JAVA中没有<<<的,因为左移后低位肯定是由0来补充的

原文地址:https://www.cnblogs.com/qie-zi/p/8715230.html

时间: 2024-10-24 03:49:57

java的<<左移,>>右移,>>>无符号右移的相关文章

java 左移&lt;&lt;&amp;&gt;&gt;右移&amp;&gt;&gt;无符号右移

java中右移运算符>>和无符号右移运算符>>>的区别 在做一个pcm音频时遇到了这个符,但是我看有些百度的地方的解释都不能令我很懂,所以就整理下. 首先左移和右移的区别是很好区分的 左移<< :就是该数对应二进制码整体左移,左边超出的部分舍弃,右边补零.举个例子:253的二进制码1111 1101,在经过运算253<<2后得到1111 0100.很简单 右移>> :该数对应的二进制码整体右移,左边的用原有标志位补充,右边超出的部分舍弃.

原码,反码,补码 与(&amp;) 或(|) 非(~) 异或(^) 左移 &lt;&lt; 右移 &gt;&gt; 无符号右移 &gt;&gt;&gt;

原码 数字在计算机中以二进制表示,8位的字长,最高位是符号位, 正数为0,负数为1.比如,3为0000 0011: -3为1000 0011. 注意,Java中int为32位.3的16进制表示为3,-3的16进制为fffffffd. 反码 正数的反码和原码相同. 负数的反码为符合位不变,其余按位取反. 3 为0000 0011: -3为1111 1100. 补码 正数的补码和原码相同. 负数的补码为反码+1. 3 为0000 0011: -3为1111 1101 与(&) 按位与,位数对齐,全部

java右移&gt;&gt; 无符号右移&gt;&gt;&gt;

>>>是无符号右移,在高位补零 >>是带符号的右移,如果是正数则在高位补零,负数则补1 int a = -1; System.out.println(a>>1); System.out.println(a>>>1); -1 2147483647 1111 1111 1111 1111 1111 1111 1111 1111       -1 1111 1111 1111 1111 1111 1111 1111 1111       -1 0111

与 或 亦或 取反 右移 无符号右移

// 提取低位的半个字节  System.out.println("01010101 & 0x00ff 结果为"+(0x55 & 0x0f));  // 按位或   // 在socket通信DataInputStream.readUnsignedShort()中用来合并byte  System.out.println("00001111 | 11110000 结果为:"+(15 | 15 << 4));  // 按位亦或  System.

java移位运算符:&lt;&lt;(左移)、&gt;&gt;(带符号右移)和&gt;&gt;&gt;(无符号右移)。

1. 左移运算符 左移运算符<<使指定值的所有位都左移规定的次数. 1)它的通用格式如下所示: value << num num 指定要移位值value 移动的位数. 左移的规则只记住一点:丢弃最高位,0补最低位 如果移动的位数超过了该类型的最大位数,那么编译器会对移动的位数取模.如对int型移动33位,实际上只移动了332=1位. 2)运算规则 按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零. 当左移的运算数是int 类型时,每移动1位它的第31位就

java移位运算符实验程序:&lt;&lt;(左移)、&gt;&gt;(带符 号右移)和&gt;&gt;&gt;(无符号右移)

public class txs { static void leftbit(){ int i;               //整型长度为32位                                                                                          //位 int num=0xFFFFFFE;  //1111 1111 1111 1111 1111 1111 1110      //28 for(i=0;i<28;i++

Java负整数的左移、右移、无符号右移

转自  Java负整数的左移.右移.无符号右移 Java负整数的左移.右移.无符号右移.正数的位移没有涉及到符号,而且正数的原码.反码.补码都是一样的,所以相对简单,但是对于负整数的位移,往往容易混淆. Java的<<  >>   >>> 都是针对补码来进行的,因为Java只存储补码. 例如对整数-3进行<<  >> >>>运算做说明. 整数-3的二进制 原码为 10000000 00000000 00000000 000

java移位运算符实验程序:&amp;lt;&amp;lt;(左移)、&amp;gt;&amp;gt;(带符 号右移)和&amp;gt;&amp;gt;&amp;gt;(无符号右移)

public class txs { static void leftbit(){ int i;               //整型长度为32位                                                                                          //位 int num=0xFFFFFFE;  //1111 1111 1111 1111 1111 1111 1110      //28 for(i=0;i<28;i++

PHP实现无符号右移(js中的 &gt;&gt;&gt;)

移位包括有符号左移(<<).有符号右移(>>).无符号右移(>>>),其中 js 支持三种移位,PHP只支持前两种移位(没查到第三种),恰好需要PHP进行无符号右移,此处实现一下.先看结果 将数字 $a 向右无符号移动 $n 位 下面是这样做的理由1.有符号右移的过程 2 >> 1 2在计算机中存储的二进制表示为 000000000 00000000 00000000 00000010 向右移动1位,高位补0 000000000 00000000 00