移位运算符例子的理解
来源:互联网 发布:程序员 那就是无业 编辑:程序博客网 时间:2024/04/26 18:21
public class URShift {
public static void main(String[] args) {
int i = -1;
i >>>= 10;
System.out.println(i);
long l = -1;
l >>>= 10;
System.out.println(l);
short s = -1;
s >>>= 10;
System.out.println(s);
byte b = -1;
b >>>= 10;
System.out.println(b);
}
} ///:~
运行结果
4194303
18014398509481983
-1
-1
进行无符号移位的时候,如上面的例子int i=-1 原码10000000 00000000 00000000 00000001 补码为
11111111 11111111 11111111 11111111无符号右移10位得到00000000 00111111 11111111 11111111
即2的22次方-1。 long l=-1是32位,原理和int一样。
对于下面的short和byte,其中short是16位,byte是8位。short s=-1;s>>>10;其中10是int(32)的,s会转换为int型
在计算机内部进行运算,但是“零扩展不会发生”,于是s运算时候的原码10000000 00000000 00000000
00000001 补码11111111 11111111 11111111 11111111,运算后为11111111 11111111 111111
结果转换为short就是10000000 00000001输出
数值的补码表示也分两种情况:
(1)正数的补码:与原码相同.
例如,+9的补码是00001001.
(2)负数的补码:符号位为1,其余位为该数绝对值的原码按位取反;然后整个数加1.
例如,-9的补码:因为是负数,则符号位为"1";其余7位为-9的绝对值+9的原码0001001按位取反为1110110;再加1,所以-9的补码是11110111.
已知一个数的补码,求原码的操作分两种情况:
(1)如果补码的符号位为"0",表示是一个正数,所以补码就是该数的原码.
(2)如果补码的符号位为"1",表示是一个负数,求原码的操作可以是:符号位不变,其余各位取反,然后再整个数加1.
例如,已知一个补码为11111001,则原码是10000111(-7):因为符号位为"1",表示是一个负数,所以该位不变,仍为"1";其余7位1111001取反后为0000110;再加1,所以是10000111.
数值在计算机中的表示——补码
在计算机系统中,数值一律用补码表示(存储),原因在于:使用补码,可以将符号位和其它位统一处理;同时,减法也可按加法来处理.另外,两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃.
- 移位运算符例子的理解
- 移位运算解决问题的例子
- 一张图理解移位运算符
- Java的移位运算符
- Java的移位运算符
- 移位运算符的优先级
- 移位运算符: > 、 >>、 >>> 的区别
- 移位运算符>>,<<,>>>的用法
- JAVA的移位运算符的方法
- JAVA的三个移位运算符
- 关于Java的移位运算符
- 关于移位运算符的知识点
- 关于移位运算符的那些事
- 关于java的移位运算符<<,>>,>>>
- C语言的移位运算符
- 移位运算的问题
- java的移位运算
- 移位运算的误区
- 保持注意力(生命技巧)--网易
- ARM初学者
- 关于java的对象数组 - 宏轩JAVA技术专栏 - CSDNBlog
- VB使用ShellExecute调用其他程序
- VMware5.0中Redhat9.0与PC文件夹共享
- 移位运算符例子的理解
- 常用标值电阻电容
- 44B0下ucos-ii的移植
- uC/OS-II中的消息邮箱
- ASP调用纯真IP库实例
- μC/OSII中的时钟中断技术研究
- 44B0之bootloader理解
- AVR应用经验
- ASP获得网卡的MAC地址