zoukankan      html  css  js  c++  java
  • C语言数据类型的表示范围

    1、C和C++语言中基本的数据类型有:字符型(char),整形(short, int, long), 浮点型(float, double) 
     

    类型

    字节数

    类型

    字节数

    char

    1

    short

    2

    int

    根据系统而定,可能是24

    long

    4

    float

    4

    double

    8

    同时字符型和整形还可以继续分为带符号的和不带符号的,默认情况下都是带符号的,如果想使用不带符号的,则使用时带上 unsigned说明即可,如果是带符号的,那么最高位将表示符号位,最高位为0表示为正数,最高位为1表示为负数,因此根据这个可以得到不同类型在分别带符号和不带符号的情况下表示的数据范围:

    类型

    范围

    类型

    范围

    signedchar

    -128——127

    unsigned char

    0——255

    (signed) short

    -32768——32767

    unsigned short

    0——65535

    (signed ) int

    -32768——32767

    -2147483648——2147483647

    unsigned int

    0——65535

    0——4294967295

    (signed) long

    -2147483648——2147483647

    unsigend long

    0——4294967295

    float

    -3.4*10-38——3.4*1038

    double

    -1.7*10-308——1.7*10308

     
    2、对于字符型和整形特别需要注意其表示的范围,如果运算导致超出其范围的处理,如以下的代码:
    1. int main() 
    2.     signed char ch = 127;
    3.     ch += 1;
    4.     printf("%d ", ch);
    5.     return 0; 
    6. }
    输出结果为:-128,注意,定义ch时赋予的值为127,已经是char能表示的最大数,其最终结果-128的来历是这样的:
    第一步:首先127在计算机中用二进制表示为:01111111;
    第二步:01111111 + 00000001 = 10000000;
    第三步:由于ch是带符号的,当最高位为1时,表示是负数,而负数的计算机中是利用补码来存储的,回忆计算负数补码的方法(首先取负数的绝对值,然后求二进制,对二进制取反,在对取反后的值加1,即为负数的补码);
    第四步:于是根据求补码的反步骤,我们来求最原始的负数,由于本题中补码为10000000,首先10000000 - 00000001 = 01111111,然后对01111111取反为10000000,10000000 = 128,由于本身是负数,即ch为-128.
     
    再看以下一段代码:
    1. int main() 
    2.     unsigned char ch = 255;
    3.     ch += 1;
    4.     printf("%d ", ch);
    5.     return 0; 
    6. }
    输出结果为:0;
    其分析为:首先ch = 255提升为整形,在计算机的存储为:(000....)11111111,然后(000....)11111111+1 = (000...)0001 00000000;然后再将最后的八位二进制截取给ch,由于最后八位全是0,因此ch = 0了。
    同理:对于遇到整形int short, long等出现上述情况时,我们也可以这样分析得到结果。
  • 相关阅读:
    KVM -> 热迁移_05
    KVM -> 虚拟机磁盘管理_03
    使用光盘搭建本地yum源
    KVM -> 虚拟机管理&console登录_02
    使用windows-SQLyog连接linux-mysql
    linux下登陆mysql失败
    忘记root密码时如何重设密码
    批处理程序:自动登陆服务端,并循环执行某些命令
    linux--磁盘分区
    linux--档案与目录管理
  • 原文地址:https://www.cnblogs.com/xunbu7/p/4287943.html
Copyright © 2011-2022 走看看