Java基本数据类型是值类型,直接存储数据、无引用和方法,栈上分配(局部变量),有明确默认值且大小范围由JVM规范固定;八种类型字节、范围及默认值均与平台无关;局部变量未初始化编译报错,成员变量自动赋默认值。

Java 中的基本数据类型是值类型,直接存储数据本身,不涉及对象引用,也不具备方法调用能力。它们在栈上分配内存(局部变量时),默认初始化值明确,且大小和取值范围由 JVM 规范严格定义,与平台无关。
基本数据类型的固定大小与默认值
Java 八种基本类型大小固定,不受操作系统或 CPU 位数影响。声明未初始化的类成员变量会自动赋予默认值;但局部变量必须显式初始化,否则编译报错 variable might not have been initialized。
-
byte:1 字节,范围 -128 ~ 127,默认值0 -
short:2 字节,范围 -32768 ~ 32767,默认值0 -
int:4 字节,范围 -2³¹ ~ 2³¹-1,默认值0 -
long:8 字节,范围 -2⁶³ ~ 2⁶³-1,默认值0L -
float:4 字节,IEEE 754 单精度,默认值0.0f -
double:8 字节,IEEE 754 双精度,默认值0.0d -
char:2 字节,Unicode 编码(0 ~ 65535),默认值'\u0000' -
boolean:JVM 规范未规定具体大小,仅允许true/false,默认值false
基本类型 vs 包装类:什么时候该用 Integer 而不是 int?
基本类型轻量、高效,适合计算密集场景;包装类是对象,支持泛型、集合、反射等,但有自动装箱/拆箱开销,且可能引发 NullPointerException。
- 用
int:循环计数、数组索引、数学运算等性能敏感路径 - 用
Integer:作为Map的 key、存入ArrayList、需区分“未设置”和“0”(如数据库字段为 NULL) - 注意:
Integer a = 127; Integer b = 127; System.out.println(a == b); // true(缓存范围内);但Integer c = 128; Integer d = 128; System.out.println(c == d); // false—— 比较务必用.equals()
浮点数比较为什么不能用 ==?
float 和 double 是二进制近似表示,存在精度丢失。直接用 == 判断相等极易出错,例如 0.1 + 0.2 != 0.3 在 Java 中返回 true。
立即学习“Java免费学习笔记(深入)”;
- 正确做法:用差值绝对值小于误差阈值,如
Math.abs(a - b) - 业务关键场景(如金额)应使用
BigDecimal,避免浮点误差累积 -
Double.compare(a, b) == 0可安全用于排序或TreeSet等需要Comparable的上下文
字符和字符串混淆:为什么 char 不能直接拼接成字符串?
char 是数值类型(本质是无符号 16 位整数),两个 char 相加会触发隐式类型提升为 int,结果是 ASCII 码之和,而非字符串连接。
char a = 'a'; char b = 'b'; System.out.println(a + b); // 输出 195(97 + 98),不是 "ab"
- 要拼接字符串,至少一个操作数需为
String类型:"" + a + b或String.valueOf(a) + b -
char可直接赋值给int:int c = 'A'; // c == 65 - 字符串字面量(如
"a")是String对象,不可赋给char;单引号内才是char字面量
最易被忽略的是布尔类型的实际存储行为——它既不是 1 字节也不是 1 位,JVM 可能用 int(4 字节)模拟,也可能压缩布局;开发者只需记住它只有两个合法值,且不能与整数互转(不像 C)。另外,所有基本类型数组(如 int[])本身是对象,但其元素仍是栈语义的值类型。










