计算机中数字都以二进制数存储,那么二进制数的有符号整数(即正负数)如何存储?根据二进制数在每个位上存储一个0或者1的规律,我们规定数字存储时最左侧的位是符号位,符号位为0表示正数,为1表示负数。
对于8个字节有符号整数来说,8个字节共8*8=64bit,最左边位符号位占1bit,后面数字位占63bit,可表示的数值范围,1111...1111(1后面63个1)~0111...1111(0后面63个1),63个1实际是多大的数?换算成十进制就是(2^62+2^61+...+2^1+2^0),这样表示不是很清楚,我们可以换一种方式:
对于二进制来说,有以下规律:
10 -1=1;
100-11=1;
1000-111=1;
...
以此类推:1000...0000(1后面63个0)-1111...1111 (63个1)=1;
因此0111...1111(0后面63个1)就可以表示为1000...0000(1后面63个0)-1,即:
1×2^63+0×2^62+...+0×2^1+0×2^0-1=2^63-1,这就是8个字节整数能表示的最大值;
同理可得1111...1111(1后面63个1)= - (2^63-1)。
需要注意的一点是,由于0000...0000(0后面63个0)与1000...0000(1后面63个0)都数值都为0,一个为﹢0一个为-0,我们规定﹢0表示真正的0,-0表示的值=最小值-1,即为;
- (2^63-1)-1= - 2^63,这就是8个字节整数能表示的最小值;
根据以上的方法,可以推导出:
1个字节有符号整数的表示范围为-2^7~2^7-1,即-128~127;
2个字节有符号整数的表示范围为-2^15~2^25-1,即-32768~32767;
4个字节有符号整数的表示范围为-2^31~2^31-1。
————————————————
版权声明:本文为CSDN博主「Sword700」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/Sword700/article/details/127353147