• 各种数据类型表示范围


     

    以前整理的找不到了,这次好好整理一下吧~~~

    一、基本类型的大小及范围的总结(以下所讲都是默认在32位操作系统下):

    字节:byte;位:bit

    1.短整型short:所占内存大小:2byte=16bit

                   所能表示范围:-32768~32767(-2^15~2^15-1)

     

    2.整型int:所占内存大小:4byte=32bit

               所能表示范围:-2147483648~2147483647(-2^31~2^31-1)

      unsigned:  所占内存大小:4byte=32bit

                   能表示范围:0~4294967295(0~2^32-1)

     

    3.长整型long:所占内存大小:4byte=32bit 
                 
    所能表示范围:-2147483648~2147483647(-2^31~2^31-1)

      unsigned long:  所占内存大小:4byte=32bit

                      所能表示范围:0~4294967295(0~2^32-1)

     

    注:上面所说的全部是有符号型的,shortintlong都默认为有符号型,其
    longint都占4个字节的空间大小,他们有什么区别呢?

          16位操作系统:long4字节,int2字节

          32位操作系统:long4字节,int4字节

          64位操作系统:long8字节,int4字节

        
    int
    型在不同位数操作系统中所占用的字节数不同,如果想编写可移植性好的程序,早年流行16位和32位操作系统时最好用long修饰int型,现在流行32位和64位操作系统,用int就挺多了。当然这些都看你怎么去理解它了,毕竟它们在不同操作系统所占字节数不固定,所以各自都有其适用之处,不可定论其好坏。
          
    下面是对它们的有科学依据的规定:

           C语言规定:无论什么平台都要保证long型占用字节数不小于int, int型不小于short型。

    4.字符型char:所占内存大小:1byte=8bit                               

                  所能表示范围:不确定!!!!;

       unsigned char:所占内存大小:1byte=8bit

                      所能表示范围:0~255(0~2^8-1)

          singned char:  所占内存大小:1byte=8bit

                         所能表示范围:-128~127(-2^7~2^7-1)

    char的默认类型不确定有可能是unsigned,也有可能是signed,主要更具编译器而定,可以自己测试一下编译器的默认char的符号类型。

    5.布尔类型bool:所占内存大小:1byte=8bit

                  所能表示的范围:只能取两个值false或者true;所以最小值就是:0 最大值:1.

    6.单精度float   所占内存大小:4byte=32bit

                    所能表示的范围:(1.17549e-038)~(3.40282e+038);

    7.双精度double:所占内存大小:8byte=32bit

                   所能表示的范围:(2.22507e-308)~(1.79769e+308);

     

           注:如何区分和使用这两个浮点类型呢,首先floatdouble的精度不同,float保留到小数点后面7位,而double保留到小

             数点后16位,float能保证6位有效数字,而double能保证15位有效数字,如果在不追求精度的的情况下当然用 float

             较好,节省内存,如果需要很高的精度的情况下,最好还是用double,平时我们定义浮点型变量一般都用double,毕竟精

             度高,一般精度的损失是不能忽略的。

     

    8.long  long类型:

         long long的表示范围:-9223372036854775808~922337203685477580719位)
         unsigned long long
    的最大值:1844674407370955161519位)

    9.字符串string:由于stringc++中属于类类型,不是基本数据类型,类不能计算其在内存中所占大小,非要用sizeof(string)来算的话,一般算出来的结果是 sizeof(string)=4byte,如果string字符串内容很多,很明显就不是其真实大小,string类里面有计算其字节大小的函数如:size(),length()

     

    
  • 相关阅读:
    Prometheus 简介
    Cassandra spring data 试用
    nginx fastcgi 优化
    mysql 用户管理
    js之iframe子页面与父页面通信
    ORACLE中SID和SERVICE_NAME的区别
    报“ Got minus one from a read call”的错误
    linux下重启oracle服务:监听器和实例
    25种提高网页加载速度的方法和技巧
    如何让你的网页加载时间降低到 1s 内
  • 原文地址:https://www.cnblogs.com/zswbky/p/5432027.html
Copyright © 2020-2023  润新知