首先放下表格
数据类型 | 写法 | 范围 | 存贮大小 |
---|---|---|---|
布尔型 | boolean | 0/1 | 1位无符号数 |
字节型 | byte | -27~27-1 | 8位带符号数 |
字符型 | char | 0~216-1 | 16位无符号数 |
短整型 | short | -215~215-1 | 16位带符号数 |
整型 | int | -231~231-1 | 32位带符号数 |
长整型 | long | -263~263-1 | 64位带符号数 |
单精度浮点型 | float | -3.403E38~3.403E38; | 32位 |
双精度浮点型 | double | -1.798E308~1.798E308 | 64位 |
类型转换
自动类型转换
Java在计算的时候自动的去把数据的类型转换,这种转换通常是从范围小的自动转换为范围大的
1、计算中:例如,双精度的数据范围显然是要比整型的大,然后Java在计算的时候就会自动的将整型的转换为双精度。
需要注意的是,这里的数据范围是值,这种数据类型可以表示的数的范围,并不是数据类型的长度,其中,单精度的范围是要比长整型的大的。
double a = 10.0;
int b = 11;
System.out.println(a*b);
2、在声明变量的时:正常我们在声明单精度等一些数据时需要在后面加上相应的符号,但是在一些情况下Java是可以自动的将数据类型转换。
其中,默认123是整型,12.0是双精度。
所以如果将12.0声明为单精度的类型时不加F在编译的时候会报错。
long a = 123L;
long b = 123;
double c = 11;
float d = 101.99F;
float e = 199;
强制类型转换
将范围大的数据类型转换为小的。
强制类型转换需要我们在写代码的时候去,显式的告诉编译器,需要将数据类型进行转换。
其中在进行强制类型转换的时候,浮点类型的数据会直接将小数部分完全舍弃,并不是四舍五入。
而将如果数据的长度大于要转换的类型,会进行裁剪。例如将1亿亿亿转换为短整型,这个时候就需要进行裁剪,但是并不是从低到高直接查16位,而是将数据转换为二进制,从低到高取16位然后将更高位舍去。
float a = (short)12.0;
int b = (int)12.33;
int a = 1234567;
short c = (short) a;
System.out.println( c ); //-10617
数据溢出
在计算的时候如果掌握不好会出现数据溢出,常见于整型或者范围更小的。
数据溢出的时候并不会报错,而是会继续进行计算,例如:
int a = Integer.MIN_VALUE;
int b = Integer.MAX_VALUE;
System.out.println( a-1 == b ); //true
所以在进行编程的时候一定要注意数据范围的问题,否则防不胜防,查BUG也不明显。
关于BYTE/CHAR
char这种数据类型是一中字符类型,具体都有那些字符大家可以去看ASCII表,这个表中将我们常见的一些字符和二进制数对应了起来。
我们就可以直接对char类型进行加减乘除计算,具体的计算方式就是先将char类型转换为int计算完毕后再转换为char类型。
char a = 'b';
System.out.println((int)a); //98
System.out.println(a+3); //101
其中,char类型也可以声明为ASCII表以外的数据,原因就是除了ASCII还有另一个表格Unicode,在这个表格里面将世上大部分的计算机会用到的字符都进行了规定,Unicode的前面和ASCII是一样的。
char a = '中';
System.out.println(a); //中
System.out.println((int)a); //20013
byte通常于I/O中进行数据传输。
自动装箱/拆箱
这是Java对基本类型和引用类型之间的一种转换。有兴趣的自己去搜吧。
//自动装箱,将基本类型转换为引用类型
Integer integer = 123;
//自动拆箱,将引用类型转换为基本类型
int a = integer;
自己进行的总结,如果有错的还请指正。