最近看移位操作的时候忘记负数的二进制表示了,网上查了一些资料,写出来备忘,复习一下。
1、原码,反码,补码
(1)原码:一个整数,按照绝对值大小转换成的二进制数,称为原码。
比如 00000000 00000000 00000000 00000101是5的原码。
(2)反码:将二进制数按位取反,所得的新二进制数称为原二进制数的反码。
取反操作指:原为1,得0;原为0,得1。(1变0; 0变1)
比如:将00000000 00000000 00000000 00000101每一位取反,得11111111 11111111 11111111 11111010。
称:11111111 11111111 11111111 11111010 是 00000000 00000000 00000000 00000101 的反码。
反码是相互的。
(3)补码:反码加1称为补码。
也就是说,要得到一个数的补码,先得到反码,然后将反码加上1,所得数称为补码。
比如:00000000 00000000 00000000 00000101 的反码是:11111111 11111111 11111111 11111010。
那么,补码为:
11111111 11111111 11111111 11111010 + 1 = 11111111 11111111 11111111 11111011
2、负数的二进制表示
举例:
-5 在计算机中表达为:11111111 11111111 11111111 11111011。转换为十六进制:0xFFFFFFFB。
-1在计算机中如何表示:
先取1的原码:00000000 00000000 00000000 00000001
得反码: 11111111 11111111 11111111 11111110
得补码: 11111111 11111111 11111111 11111111
可见,-1在计算机里用二进制表达就是全1。16进制为:0xFFFFFFFF。
注:十六进制前缀是0x。
以0x开始的数据表示16进制,计算机中每位的权为16,即(16进制)10 = (10进制)1×16。
C,C++规定,16进制数必须以 0x开头。比如 0x1表示一个16进制数。而1则表示一个十进制。另外如:0xff,0xFF,0X102A,等等。其中的x也不区分大小写。(注意:0x中的0是数字0,而不是字母O)
3、如何判断一个二进制数是否为负数
首先看是不是无符号数,开头第一位是符号位,1表示负数,0表示正数。
其次看操作系统的位数。若是8位的,1111 1111就是-1,若是16位的FFFF即是-1,若是32位的FFFF FFFF即是-1。比如10101010在8位系统下是负数,在16和32位下就不是。101在8位和8位以上的操作系统中是正数。
参考资料:
负数如何用二进制表示