Java入门需先理解main方法签名、==与equals区别、变量初始化规则及final真实含义:main必须public static void因JVM硬性校验;==比地址,equals比内容但依赖重写;局部变量须显式初始化,成员变量有默认值;final修饰引用仅锁引用不锁对象。

Java 入门不是从“Hello World”开始的,而是从理解 public static void main(String[] args) 为什么必须长这样开始。
为什么 main 方法必须是 public static void?
这不是约定,是 JVM 启动时硬性校验的签名。JVM 不会反射查找“类似”的方法,只认这个确切签名:
-
public:保证 JVM(外部类)能访问它 -
static:避免在调用前创建对象——此时对象还没初始化 -
void:JVM 不处理返回值,返回值无意义 -
String[] args是唯一被识别的参数类型;用List或String...(虽语法合法)会导致NoClassDefFoundError或直接启动失败
== 和 .equals() 到底在比什么?
根本区别在于:一个比内存地址,一个比逻辑内容。但关键陷阱不在“是什么”,而在“谁重写了 equals()”:
-
Integer、String、LocalDateTime等 JDK 类重写了equals(),比较的是值 - 自定义类默认继承
Object.equals(),等价于==,永远不相等(除非是同一个对象) -
==对基本类型(int,boolean)比较值,对引用类型比较堆地址——哪怕两个new String("a")内容相同,==也是false - 用
Objects.equals(a, b)可安全规避null检查,比手写a != null && a.equals(b)更可靠
局部变量必须显式初始化,但成员变量不用?
这是 Java 编译器的“确定性赋值检查”机制决定的,和内存模型无关:
Perl 基础入门中文教程,chm格式,讲述PERL概述、简单变量、操作符、列表和数组变量、文件读写、模式匹配、控制结构、子程序、关联数组/哈希表、格式化输出、文件系统、引用、面向对象、包和模块等知识点。适合初学者阅读和了解Perl脚本语言。
立即学习“Java免费学习笔记(深入)”;
- 局部变量(方法内声明)没有默认值,未赋值就使用会编译报错:
variable xxx might not have been initialized - 成员变量(字段)由 JVM 在对象实例化时自动赋予默认值(
0、false、null),所以不显式初始化也能通过编译 - 注意:这种“默认初始化”只发生在堆上新对象创建时;局部变量在栈帧中分配,生命周期短,编译器强制你明确它的初始状态
- 即便
int字段默认是0,也建议显式初始化(如private int count = 0;),避免语义模糊
final 修饰引用类型时,“不可变”到底指什么?
很多人误以为 final List 能防止修改内容——其实只能防止重新赋值:
-
list = new ArrayList();→ 编译错误(引用不可再指向别处) -
list.add("x");→ 完全合法(对象内部状态可变) - 要真正不可变,得用
Collections.unmodifiableList()包装,或用List.of()(Java 9+)创建不可变副本 -
final修饰基本类型(如final int x = 5;)才真正锁定值;修饰引用类型只锁住“指向”,不锁住“指向的对象”
Java 基础里最易被跳过的,其实是那些“看起来理所当然”的设计约束——比如为什么 main 必须是 static,为什么 final 对集合无效。这些不是语法细节,而是 JVM 运行机制在 API 层的投射。绕开它们去写代码,早晚会撞上 NoClassDefFoundError 或诡异的 null 引用。









