C++基本数据类型解读

来源:互联网 发布:haskell人工智能 编辑:程序博客网 时间:2024/06/01 08:35

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

原码    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位。

0 0
原创粉丝点击