Java的基本类型分为整型(byte、short、int、long)、浮点型(float、double)、字符型(char)和布尔型(boolean)4种。
每一种基本类型都对应有一个封装类,方便涉及类和对象的操作。基本类型与对应封装类对象的相互转换:
装箱:将基本类型的变量转换成对应引用类型的变量。
拆箱:将引用类型的变量转换成对应基本类型的变量。
整型
整型变量用于表示带符号的整数。可以使用十进制、十六进制(以“0X”或“0x”开头)和八进制(以“0”开头)赋值。分为4种:
byte:表示8位二进制带符号整数。
范围:-27~27-1
默认值:0
封装类:java.lang.Byte
short:表示16位二进制带符号整数。
范围:-215~215-1
默认值:0
封装类:java.lang.Short
int:表示32位二进制带符号整数。
范围:-231~231-1
默认值:0
封装类:java.lang.Integer
long:表示64位二进制带符号整数。赋值需要以“L”或“l”结尾。
范围:-263~263-1
默认值:0
封装类:java.lang.Long
浮点型
浮点型变量用于表示带符号的浮点数,浮点数通过四舍五入处理超出有效位数的小数部分。浮点数后加上“F”或“f”表示单精度浮点数,不加或者加上“D”或“d”表示双精度浮点数。分为2种:
float:表示32位二进制单精度浮点数。
符号位:1
指数位:8
尾数位:23
有效位数:8
绝对值范围:1.4e-45f~3.4028235e+38f
默认值:0.0f
封装类:java.lang.Float
double:表示64位二进制双精度浮点数。
符号位:1
指数位:11
尾数位:52
有效位数:16
绝对值范围:4.9e-324~1.7976931348623157e+308
默认值:0.0
封装类:java.lang.Double
字符型
字符型变量用于表示Unicode字符。字符型变量赋值有两种方式,一种是使用单引号将单个字符括起来,另一种是直接赋无符号整数。
char:表示16位无符号整数。只存储单个字符。
范围:0~216-1
默认值:0
封装类:java.lang.Character
布尔型
布尔型变量可取逻辑真和逻辑假两种值。布尔型变量不能与0和1对等。
boolean:表示一个判断的逻辑结果。
取值:true(逻辑真)、false(逻辑假)
默认值:false
封装类:java.lang.Boolean
测试
如果在方法中定义变量,使用时需要为变量赋初值。为了查看默认值,把所有变量都定义为成员变量。
byte
1 byte b;2 @Test3 void testByte() {4 System.out.print("byte: " + b);5 b = 10;6 System.out.println(" -> " + b);7 System.out.println("取值范围:[ " + Byte.MIN_VALUE + ", " + Byte.MAX_VALUE + " ]");8 }
输出结果:
short
1 short s;2 @Test3 void testShort() {4 System.out.print("short: " + s);5 s = 200;6 System.out.println(" -> " + s);7 System.out.println("取值范围:[ " + Short.MIN_VALUE + ", " + Short.MAX_VALUE + " ]");8 }
输出结果:
int
1 int i;2 @Test3 void testInt() {4 System.out.print("int: " + i);5 i = 40000;6 System.out.println(" -> " + i);7 System.out.println("取值范围:[ " + Integer.MIN_VALUE + ", " + Integer.MAX_VALUE + " ]");8 }
输出结果:
long
1 long l;2 @Test3 void testLong() {4 System.out.print("long: " + l);5 l = 8000000000l;6 System.out.println(" -> " + l);7 System.out.println("取值范围:[ " + Long.MIN_VALUE + ", " + Long.MAX_VALUE + " ]");8 }
输出结果:
float
1 float f;2 @Test3 void testFloat() {4 System.out.print("float: " + f);5 f = 0.123456789f; // 超出8位有效数字6 System.out.println(" -> " + f);7 System.out.println("绝对值范围:[ " + Float.MIN_VALUE + ", " + Float.MAX_VALUE + " ]");8 }
输出结果:
double
1 double d;2 @Test3 void testDouble() {4 System.out.print("double: " + d);5 d = 0.12345678123456789; // 超出16位有效数字6 System.out.println(" -> " + d);7 System.out.println("绝对值范围:[ " + Double.MIN_VALUE + ", " + Double.MAX_VALUE + " ]");8 }
输出结果:
char
1 char c;2 @Test3 void testChar() {4 System.out.print("char: " + (int) c); // 0对应的Unicode字符为非打印字符,故转成int型5 c = '符';6 System.out.print(" -> " + c);7 c = 31526;8 System.out.println(" -> " + c);9 }
输出结果:
boolean
1 boolean bool;2 @Test3 void testBoolean() {4 System.out.print("boolean: " + bool);5 bool = true;6 System.out.println(" -> " + bool);7 }
输出结果: