C++基本数据类型解读

ANSI C/C++基本数据类型 32位系统
TypeSize/byte(字节)数值范围
void无值域
bool1true false
short [int] / signed short [int]2-32768~32767
unsigned short [int]20~65535
int / signed [int]4-2147483648~2147483647
unsighed [int]40~4294967295
long [int] / signed long [int]4-2147483648~2147483647
unsigned long [int]40~4294967295
long long8 
char / signed chat1-128~127
unsigned char10~255
wchar_t(unsigned short)20~65535
float4-3.4E-38~3.4E+38
double8-1.7E-308~1.7E+208
long double8 

  














有几点要说明下:

 1 机器数:

 一个数在计算机中的二进制表示形式,  叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1。

        00010000就是机器数。

 2 真值:

将带符号位的机器数对应的真正数值称为机器数的真值。

00010000的真值就是32;10000001的真值是-1。

 3 计算机里采用补码表示:

例如 原码=00010000  原码=10000001

反码=00010000  反码=11111110

补码=00010000  补码=11111111

 4 char的所占byte为1,所以char是8位二进制数,所以对应的最大最小值如下:

           -128=-(127+1)                 -127                 0                 127              128=127+1

原码    10000000       11111111        00000000    01111111   10000000

反码    11111111       10000000        01111111    01111111   10000000

补码    10000000       10000001        00000000    01111111   10000000

128的机器数最高位为1与其本身是负数矛盾,而-128的补码10000000是唯一的,所以char的范围为-128~127。其他数据类型同理。

5 关于long和int

   16位系统:long是4字节,int是2字节。

   32位系统:long是4字节,int是4字节。

   64位系统:long是8字节,int是4字节。

6 关于float和double

   浮点数在机内用整数型表示,分为:数符,尾数,指数符,指数。

   这里呢float    数符+尾数 24位,指数符+指数8位;

             double 数符+尾数 48位,指数符+指数16位。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值