一、Java中的8种基本类型
byte:1个字节,8位,表示的整数的范围是[-2^7 , 2^7-1],即[-128,127]
short:2个字节,16位,表示的整数的范围是[-2^15 , 2^15-1],即[-32768,32767]
int:4个字节,32位,表示的整数的范围是[-2^31 , 2^31-1],即[-2 147 483 648,2 147 483 647],大概21亿
long:8个字节,64位,表示的整数范围是[-2^63 , 2^63-1],大概就是21亿乘21亿乘2,可以说是一个天文数字了。代码中长整形数字后面要加上大写的L。
整数在计算机中是以二进制补码存储的,这么存储的意义是方便加减乘除运算。整数有正负之分,最高位为符号位,0表示正数,1表示负数。正数的原码、反码、补码是其本身,负数的反码是原码符号位不变,其余位取反而来,补码则是反码+1。以8位举例,最大为01111111(反码)=127,10000001(反码)=-127,正0和负0的补码表示均为00000000,而1000000(反码)对应不了任何数,所以规定其为-128,所以1个字节的byte类型的表示范围是[-128,127],其他类型同理。
float:单精度浮点型,4个字节,32位
double:双精度浮点型,8个字节,64位
单精度及双精度浮点数在计算机中的存储及带来的精度损失问题:待续..
boolean:布尔值,具体占多少空间在Java规范中并没有指出,boolean所占的空间跟虚拟机的具体实现有关。可能是4个字节,因为编译后使用int类型来代替,而boolean数组编译后是byte数组,则每个boolean占一个字节。
char:字符,2个字节,16位。
JVM中内码采用UTF16,UTF16早期是用2个字节表示一个字符,后期由于字符的增多,2个字节无法表示所有的字符,所以有的字符用4个字节表示,但是这并不是说Java中char型有时候占2个字节,有时候占4个字节,而是需要用4个字节表示的字符是用2个char来表示的。其中内码是指在运行时,char型在内存中的编码方式。
而对于Java源文件,其编码方式可以由用户指定,一般用UTF8。源文件编译之后的class文件,字符的编码方式是UTF8。UTF8是一种变长的字符表示方式,从1个字节到6个字节。其中英文字符一般是1个字节,中文字符一般是3个字节。
二、Java中8中基本数据类型对应的包装类
byte --> Byte
short --> Short
int --> Integer
long --> Long
float --> Float
double --> Double
boolean --> Boolean
char --> Character
Byte、Short、Integer、Long、Float、Double是Number的子类,Boolean和Character是Object类的子类。
包装类实现了很多方法,比如valueOf()方法,parseXXX()方法,equals()等等,具体参见源码。
#tips#
Integer i = 100;
Integer j = 100;
i == j; // true
Integer k = 200;
Integer m = 200;
k == m; // false
为什么上面为true,下面为false?
原因是:Java在创建Byte,Short,Integer,Long对象时,如Integer i = 100; 底层是Integer i = Integer.valueOf(100); 看valueOf(int)的源码可知,有一个[-128,127]的缓存,如果int的值在此之间,按照此种方式创建的对象是缓存里的同样的对象,而对于不在此区间内的值则是new 出一个对象,‘==’操作符比较的是对象的地址,所以相同的对象返回true,不同则返回false。所以在比较对象是否相等时,建议用equals。