• Java的基本数据类型


    Java共有8种基本数据类型(四个整数型、两个浮点型、一个字符型、一个布尔型)

    boolean byte char short int long float double
    1字节 2字节 2字节 4字节 8字节 4字节 8字节

    四个整型

    byte

    • 8位,取值范围:-128~127
    • 默认值为0,占用1个字节

    short

    • 16位,取值范围:- 215~(215 - 1)
    • 默认值为0,占用2个字节

    int

    • 32位,取值范围 : -231~(231 - 1)
    • 默认值为0,占用4个字节

    long

    • 64位,取值范围 : -263~(263- 1)
    • 默认值为0,占用8个字节

    两个浮点型(不能用来表示精确值,如金融)

    float

    • 单精度32位,尾数长度23,指数长度8,指数偏移量127
    • 默认值为0.0f,占用4个字节

    double(浮点数的默认类型是double)

    • 双精度64位,尾数长度52,指数长度11,指数偏移量1023
    • 默认值为0.0d,占用8个字节

    一个字符型

    char

    • 单一的16位Unicode字符,取值范围: u0000~uffff 即(0~65535)
    • 默认值为u0000(即为0),占用2个字节

    一个布尔型

    boolean

    • 只有两种取值: true和false。默认值为false
    关于boolean占用几个字节,网上有几点说法
    1. 1个bit(八分之一字节)

    boolean类型值只有true和false,在编译后使用1和0表示,这两个数在内存中只需要1位(bit)即可存储,位是计算机最小的存储单位

    2. 1个字节

    虽然编译后1和0只需占用1位空间,但计算机处理数据的最小单位是1个字节,1个字节等于8位,实际存储的空间是:用1个字节的最低位存储,其他7位用0填补,如果值是true的话则存储的二进制为:0000 0001,如果是false的话则存储的二进制为:0000 0000

    3. 4个字节

    《Java虚拟机规范》一书中的描述:“虽然定义了boolean这种数据类型,但是只对它提供了非常有限的支持。在Java虚拟机中没有任何供boolean值专用的字节码指令,Java语言表达式所操作的boolean值,在编译之后都使用Java虚拟机中的int数据类型来代替,而boolean数组将会被编码成Java虚拟机的byte数组,每个元素boolean元素占8位”。这样我们可以得出boolean类型占了单独使用是4个字节,在数组中又是1个字节。

    显然第三条是更准确的说法,那虚拟机为什么要用int来代替boolean呢?为什么不用byte或short,这样不是更节省内存空间吗。大多数人都会很自然的这样去想,我同样也有这个疑问,经过查阅资料发现,使用int的原因是,对于当下32位的处理器(CPU)来说,一次处理数据是32位(这里不是指的是32/64位系统,而是指CPU硬件层面),具有高效存取的特点。

    最后的总结:

    根据http://docs.oracle.com/javase/tutorial/java/nutsandbolts/datatypes.html官方文档的描述:

    boolean: The boolean data type has only two possible values: true and false. Use this data type for simple flags that track true/false conditions. This data type represents one bit of information, but its "size" isn't something that's precisely defined.

    布尔类型:布尔数据类型只有两个可能的值:真和假。使用此数据类型为跟踪真/假条件的简单标记。这种数据类型就表示这一点信息,但是它的“大小”并不是精确定义的。

    可以看出,boolean类型没有给出精确的定义,《Java虚拟机规范》给出了4个字节,和boolean数组1个字节的定义,具体还要看虚拟机实现是否按照规范来,所以1个字节、4个字节都是有可能的。这其实是运算效率和存储空间之间的博弈,两者都非常的重要

    基本数据类型对应的包装类

    数据类型 包装类
    byte Byte
    short Short
    int Integer
    long Long
    float Float
    double Double
    char Character
    boolean Boolean

    总结

    所有字节数相对少的基本数据类型可以自动向字节数相对多的转换。byte、char、short会自动转成int型,long可以自动转成float或double,float可以自动转换成double

    参考链接

    菜鸟教程:http://www.runoob.com/java/java-basic-datatypes.html

    简书:https://www.jianshu.com/p/2f663dc820d0

  • 相关阅读:
    【转】winrar命令行详解
    【转】关于色彩空间sRGB和Adobe RGB...
    深入解读TPC-C指标
    解决因 RsFX devicer 而无法卸载 SQL Server 的问题
    LUHN算法
    信用卡卡号编排的含义
    关于第三方API调用的工具 WebApiClient.JIT 的使用记录
    ocelot.json模板
    C#进阶之事件与委托(Event&Delegate)
    C#进阶之面向对象(OOP)
  • 原文地址:https://www.cnblogs.com/my12/p/10492220.html
Copyright © 2020-2023  润新知