Java中有以下几种基本数据类型,这些类型都是值类型。
|类型 |值范围 |大小 |范围 |
|----|-----|
|boolean |true或false |1位 ||
|char |Unicode字符 |16位| '\u0000'~'\uFFFF'|
|byte |有符号整数 |8位| -128~127 |
|short |有符号整数 |16位 |-32768~32767
|int |有符号整数 |32位 |-231~231-1
|long |有符号整数 |64位 |-263~263-1|
|float |IEEE 754浮点数| 32位 |1.4E-45~3.4028235e+38|
|double |IEEE 754浮点数|64位 |4.9E-324~1.7976931348623157E+308|
布尔类型
boolean是布尔类型,用来表示逻辑真值,只有两个值,真和假。而且不能和其他基本类型进行类型转换,主要作用是在条件和判断语句中作为判断条件。
各种基本类型的值可以直接出现在程序中,这样的值叫做字面量。对于布尔类型来说,字面量只有true
和false
两个。
boolean condition = true;
if(condition) {
...
}
字符类型
char也就是字符类型,用来表示一个Unicode字符。除了可以使用普通字符外,还可以使用各种转义字符以及Unicode转义序列与一些非打印字符。字符类型的字面量,必须使用单引号'
包裹起来。
char c = 'A';
char tab = '\t';
char nul = '\000';
转义字符 | 含义 |
---|---|
\b | 退格符 |
\t | 水平制表符 |
\n | 换行符 |
\f | 换页符 |
\r | 回车符 |
" | 双引号 |
' | 单引号 |
\|反斜杠 | |
\xxx | Latin-1字符,其中xxx是八进制数 |
\uxxxx | Unicode字符,其中xxxx是十六进制数 |
char类型和其他数字类型可以互相转换。但是转换之后的意义可能会发生变化。另外需要说一点,在Java中,对于Unicode转义序列的处理和其他语言有些不同。在Java源代码中的任意位置,都可以使用Unicode转义序列,甚至是关键字都可以。
整数类型
Java中有byte
、short
、int
、long
四中整数类型,它们的主要区别在于表示范围的不同。由于现在计算机性能和存储空间都有了极大的增长,所以byte
和short
两种类型已经很少用了,一般情况下都使用int
类型,只有当int
类型不够的时候才使用long
类型。
有过C语言学习经验的同学可能知道C语言中有一个unsigned
关键字,表示无符号类型,但是在Java中没有这个关键字。这就意味着,Java中的所有整数,都是有符号整数。
byte b = 10;
short s = 50000;
int i = 12345678;
long l = 1234567890;
整数字面量 | 含义 |
---|---|
5000 | 普通数字,看做int 字面量 |
5000L | 后缀l 或L ,long 字面量 |
0b0001 | 前缀0b ,二进制数字,即十进制的1 |
0007 | 前缀0 ,八进制数字,即十进制的1 |
0xff | 前缀0x 或0X ,十六进制数字,即十进制的255 |
另外,在整数字面量中还可以使用下划线增强可读性,下划线会被程序忽略,不影响数字的值。由于八进制数字以0作为前缀,容易引起混淆,因此在程序中应避免使用。
在Java中使用整数类型,应注意其范围,避免产生溢出等情况。如果数据溢出,就会出现回绕情况。例如
byte a = 127;
byte b = 1;
byte sum = (byte)(a + b); //结果为-128,发生回绕
浮点数类型
浮点数即小数,由于在计算机中存储的时候位数是固定的,而小数点会发生移动,因此得名浮点数。在Java中有float
和double
两种类型。float
是单精度浮点数,有至少6位有效数字。double
是双精度浮点数,至少有15位有效数字。
float f = 12.34F;
double d = 123.456;
d = 1.23E5;
需要注意默认情况下浮点数被认为是double
型字面量,如果想要使用float
型字面量,需要添加f
或F
后缀。另外,还可以使用科学计数法表示浮点数。
注意,由于二进制数和十进制数无法进行精确转换,所以Java中的float和double都是近似的,在进行计算的时候需要格外小心,避免产生无法预料的后果。
类型转换
除了布尔类型之外,其余所有的基本类型之间都可以进行互相转换。在转换的时候需要注意数字的范围,如果由小范围向大范围转换,数字精度不会丢失,这样的转换就可以直接进行,称作隐式转换。如果由大范围向小范围转换,数字精度会丢失,这样的转换默认情况下不允许进行。这种情况下需要使用强制类型转换,在要转换的数字前面添加一对括号和要转换的类型,这叫做显式转换。
byte small = 12;
int big = 300;
big = small; //小范围向大范围转换
small = (byte) big; //大范围向小范围转换,需要强制类型转换
浮点数转换成整数的时候,小数部分会被直接截取。
int i = 10;
double d = 12.34;
i = (int) d; //现在是12,小数部分被丢弃