标签:
原码:就是二进制定点表示法,即最高位为符号位,“0”表示正,“1”表示负,其余位表示数值的大小。
反码:正数的反码与其原码相同;负数的反码是对其原码逐位取反,但符号位除外。
补码:正数的补码与其原码相同;负数的补码是在其反码的末位加1。
计算机表示出来的是原码,在内存中参与计算的是补码。
位运算符 |
||
运算符 |
运算 |
范例 |
<< |
左移 |
3 << 2 = 12 --> 3*2*2=12 |
>> |
右移 |
3 >> 1 = 1 --> 3/2=1 |
>>> |
无符号右移 |
3 >>> 1 = 1 --> 3/2=1 |
& |
与运算 |
6 & 3 = 2 |
| |
或运算 |
6 | 3 = 7 |
^ |
异或运算 |
6 ^ 3 = 5 |
~ |
反码 |
~6 = -7 |
任何二进制位和0进行&运算,结果是0;和1进行&运算结果是原值。(有0则0)
int a=10; int b=20; System.out.println(a&b); * a=10 的二进制是:00000000 00000000 00000000 00001010 * b=20 的二进制是:00000000 00000000 00000000 00010100 * 00000000 00000000 00000000 00001010 * & * 00000000 00000000 00000000 00010100 * ------------------------------------------- * 00000000 00000000 00000000 00000000 * 结果是:0
int a=10; int b=20; System.out.println(a|b); * a=10 的二进制是:00000000 00000000 00000000 00001010 * * b=20 的二进制是:00000000 00000000 00000000 00010100 * * 00000000 00000000 00000000 00001010 * | * 00000000 00000000 00000000 00010100 * ------------------------------------------- * 00000000 00000000 00000000 00011110 * 结果是: 30
int a=10; int b=20; System.out.println(a^b); * a=10 的二进制是:00000000 00000000 00000000 00001010 * * b=20 的二进制是:00000000 00000000 00000000 00010100 * * 00000000 00000000 00000000 00001010 * ^ * 00000000 00000000 00000000 00010100 * ------------------------------------------- * 00000000 00000000 00000000 00011110 * 结果是: 30
int a=10; System.out.println(~a); * 00000000 00000000 00000000 00001010 * ~ * ------------------------------------------- * 11111111 11111111 11111111 11110101 补码 * 11111111 11111111 11111111 11110100 反码 * 10000000 00000000 00000000 00001011 原码 * 结果是:10
int a=3<<4; System.out.println(a); /*把3的二进制位向左移动4位 * 00000000 00000000 00000000 00000011 * (0000)0000 00000000 00000000 00000011(0000) * 二进制结果:00110000 转换成十进制结果: 48
int e=-5<<4; System.out.println(e); /*把-5向左移动4位 * 10000000 00000000 00000000 00000101 原码 * 11111111 11111111 11111111 11111010 反码 * 11111111 11111111 11111111 11111011 补码 * 11111111 11111111 11111111 11111011(0000) * 1111 11111111 11111111 111110110000 补码 * 1111 11111111 11111111 111110101111 反码 * 1000 00000000 00000000 000001010000 原码 * 十进制结果-80 */
int b=5>>4; /*把5的二进制位向右移动4位 * 00000000 00000000 00000000 00000101 * (0000)00000000 00000000 00000000 0000(0101) 结果是:0
int d=-5>>4; System.out.println(d); /*把-5向右移动4位 * 10000000 00000000 00000000 00000101 原码 * 11111111 11111111 11111111 11111010 反码 * 11111111 11111111 11111111 11111011 补码 * 111111111111 11111111 11111111 1111(1011) * 111111111111 11111111 11111111 1111 补码 * 111111111111 11111111 11111111 1110 反码 * 100000000000 00000000 00000000 0001 原码 * 十进制结果-1 */
int b=5>>>4; /*把5的二进制位向右移动4位 * 00000000 00000000 00000000 00000101 * (0000)00000000 00000000 00000000 0000(0101) 结果是:0
计算出24的二进制:11000 :-24 >>> 2 原码:10000000 00000000 00000000 00011000 反码:11111111 11111111 11111111 11100111 补码:11111111 11111111 11111111 11101000 11111111 11111111 11111111 11101000 0011111111 11111111 11111111 111010(00)
标签:
原文地址:http://blog.csdn.net/msq7487223/article/details/51352880