计算机中的数据都以二进制的形式存在,其中第一位作为我们的符号位,与数据共享一个存储空间,关于位运算符,呕心沥血,经过近两个小时的在纸上画写,终于有所感悟!!!!!
位运算右操作数要完成模32的运算,右移位运算右操作数要完成模32的运算,右移位运算右操作数要完成模32的运算,重要的事情说三遍!!!
简单来说也就是先将该数据转化为int(32位)在进行运算
"<<":左移位运算符,以0补全低位
byte a = -1; //1111 1111 1111 1111 1111 1111 1111 1111
System.out.println(a<<4); //1111 1111 1111 1111 1111 1111 1111 0000(补)
//1000 0000 0000 0000 0000 0000 1001 0000(原)
输出结果:
-16
">>":带符号右移位运算符,以符号为填充高位
byte a = -1; //1111 1111 1111 1111 1111 1111 1111 1111
System.out.println(a>>4);//以符号为1填充高位1111 1111 1111 1111 1111 1111 1111 1111(补)
//1000 0000 0000 0000 0000 0000 0000 0001(原)
输出结果:
-1
">>>":无符号右移运算符,无视符号位,以0填充高位,无">>>"运算符的存在。
byte a = -1; //1111 1111 1111 1111 1111 1111 1111 1111
System.out.println(a>>4);//以0填充高位0000 1111 1111 1111 1111 1111 1111 1111
输出结果:
268435455