码迷,mamicode.com
首页 > 编程语言 > 详细

Visual C++中int表示的范围

时间:2018-07-25 13:49:39      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:visual   计算   处理   bubuko   nbsp   idt   补码   理解   .com   

在Visual C++中的int整型一般由四个字节表示

技术分享图片

技术分享图片

在计算机中采用补码形式存储int(对于正数其补码与原码相等),

补码的数字从0000 0000 0000 0000 0000 0000 0000 0000~1111 1111 1111 1111 1111 1111 1111 1111

通过补码和原码的转换规则,1111 1111 1111 1111 1111 1111 1111 1111表示的值为-1;

1111 1111 1111 1111 1111 1111 1111 1110表示的值为-2;

1111 1111 1111 1111 1111 1111 1111 1101表示的值为-3;

1000 0000 0000 0000 0000 0000 0000 0001表示的值为-2147483647;

将1000 0000 0000 0000 0000 0000 0000 0000硬性规定为-2147483648;

简化性的理解:

 对于一个8字节的整数(int)来说,范围是2的8次方,表示-128~127。如下面的表格所示,如果用原码和反码,

+0和-0是同一个数却有两个不同的表示,这样不仅会使计算机多一层处理,还会浪费一个表示范围;而补码就能很好的解决这个问题。

(-128只有补码,而没有原码和反码,因为数值位只能表示0~127。)

 

Visual C++中int表示的范围

标签:visual   计算   处理   bubuko   nbsp   idt   补码   理解   .com   

原文地址:https://www.cnblogs.com/denghui666/p/9365440.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!