Java构造方法由new隐式触发,必须与类名完全一致且无返回类型;this()委托须首行唯一;父类无参构造缺失时子类须显式调用super(...);构造器中可return;但不可返回值;严禁泄露未完成初始化的this。

Java 构造方法不是“调用”的,而是通过 new 表达式隐式触发的;写错签名、漏写访问修饰符、或在构造器里调用未初始化的 this(),都会直接编译失败。
构造方法必须和类名完全一致且无返回类型
这是最常被初学者误写的地方:加了 void、拼错类名、或首字母小写,都会让编译器当成普通方法,导致 new 时找不到构造器。
-
public class Person { public Person() { } }✅ 正确 -
public void Person() { }❌ 编译错误:这不是构造器,是返回void的普通方法 -
public person() { }❌ 类名首字母必须大写,否则不匹配
重载多个构造器时,this(...) 必须是第一行且只能出现一次
用 this() 委托另一个构造器,是为了复用初始化逻辑。但语法约束极严:它必须是构造器体内的第一条语句,且不能和 super() 共存。
public class Point {
private int x, y;
public Point() {
this(0, 0); // ✅ 第一行,调用本类另一个构造器
}
public Point(int x, int y) {
this.x = x;
this.y = y;
}
public Point(int x) {
super(); // ❌ 错误:this() 和 super() 不能同时存在
this(x, 0);
}
}
父类无参构造器不存在时,子类必须显式调用 super(...)
如果父类只定义了带参构造器(比如 public Animal(String name)),而没写无参构造器,那么子类所有构造器都必须第一行写 super("xxx"),否则编译报错 Implicit super constructor Animal() is undefined。
立即学习“Java免费学习笔记(深入)”;
- 父类写了
Animal(String name)→ 子类构造器必须显式调用super("dog") - 父类没写任何构造器 → 编译器自动补一个无参
super(),子类可不写 - 父类写了无参构造器 + 带参构造器 → 子类可自由选择是否显式写
super()
构造器里不能使用 return 返回值,但可以写 return;
构造器没有返回类型(连 void 都不能写),所以不能 return someObject;。不过空 return; 是合法的,常用于提前退出分支逻辑,但极少需要。
public class Config {
public Config(String path) {
if (path == null) {
throw new IllegalArgumentException("path cannot be null");
}
if (path.isEmpty()) {
return; // ✅ 合法,等价于结束当前构造流程(此时对象已部分初始化)
}
loadFromFile(path);
}
}
真正容易出问题的,往往不是语法本身,而是构造器执行时机——它发生在对象内存分配之后、引用赋值之前;若在构造器中泄露 this(比如启动线程、注册监听器、传给静态集合),就可能让未构造完成的对象被外部访问到。










