乐趣区

关于html5:如何运用Java中的位移运算符

学习 Java 原本就是一件与日俱增的事件,或者你通过自学能把握一些皮毛技术,通过零碎学习学到 Java 的一些根本大面,但想要做到精通,还是须要本人技术的与日俱增和工作教训的一直积攒。

1)“有符号”左移位运算符 (<<) 能将运算符右边的运算对象向左挪动运算符右侧指定的位数(在低位补 0)。

左移移位相当于乘以 2,例如

3 << 2 //12 则是将数字 3 左移 2 位 322 = 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,而后把低位的 www.sangpi.com 最初两个数字移出,因为该数字是负数,所以在高位补零。则失去的最终后果是 0000 0000 0000 0000 0000 0000 0000 0010. 转换为十进制是 3. 数学意义:右移一位相当于除 2,右移 n 位相当于除以 2 的 n 次方。

3) Java 也增加了一种“无符号”右移位运算符(>>>),它应用了“零扩大”:无论正负,都在高位插入 0

4)右移一位相当于除以 2,左移一位 (在不溢出的状况下) 相当于乘以 2; 移位运算速度高于乘除运算。

5)位运算符的优先级

~ 的优先级最高,其次是 <<、>> 和 >>>,再次是 &,而后是 ^,优先级最低的是 |。

退出移动版