原码 反码 补码,位运算(左移 右移 无符号右移)
原码(2)正数的反码、补码与原码相同;
0000 0000 0000 0000 0000 0000 0000 0010
原码(-2)
1000 0000 0000 0000 0000 0000 0000 0010
反码(-2)原码的符号位不变,其他位取反;
1111 1111 1111 1111 1111 1111 1111 1101
补码(-2)反码+1;
1111 1111 1111 1111 1111 1111 1111 1110
任何数据都是以二进制的补码形式储存在内存中的;
补码转换成原码:符号位不变,其他位取反,再加1;
补码(2)
0000 0000 0000 0000 0000 0000 0000 0010
左移(<<)5位
0000 0000 0000 0000 0000 0000 0100 0000
补码(-2)
1111 1111 1111 1111 1111 1111 1111 1110
左移(<<)5位(左移不会影响操作符,右侧用0补充);
1111 1111 1111 1111 1111 1111 1100 0000
补码(2)
0000 0000 0000 0000 0000 0000 0000 0010
有符号右移(>>)5位(以符号位填充);
0000 0000 0000 0000 0000 0000 0000 0000
补码(-2)
1111 1111 1111 1111 1111 1111 1111 1110
有符号右移(>>)5位(以符号位填充);
1111 1111 1111 1111 1111 1111 1111 1111
补码(2)
0000 0000 0000 0000 0000 0000 0000 0010
无符号右移(>>>)5位(补0);
0000 0000 0000 0000 0000 0000 0000 0000
补码(-2)
1111 1111 1111 1111 1111 1111 1111 1110
无符号右移(>>>)5位(补0);
0000 0111 1111 1111 1111 1111 1111 1111
此时计算机会直接把移位后的补码直接当成原码,从而转换为十进制;(在有符号的情况下,一般要把补码转换成原码后,再转换成十进制)
注:
正数的无符号右移和有符号右移结果相同
">>>"无符号右移
操作规则:无论正负数,前面补零。
">>"右移
操作规则:正数前面补零,负数前面补1
"<<"左移
操作规则:无论正负数,后面补零。
共同学习,写下你的评论
评论加载中...
作者其他优质文章