构造方法的核心作用是初始化新创建的对象,它在new表达式执行时被自动调用,确保对象诞生时处于可用、一致的状态;仅响应new操作,不显式调用,不自动继承;无默认构造方法时需手动定义;重载依赖参数列表;this()和super()必须首行且互斥;禁止调用可重写方法、执行高风险操作或泄露this引用。

构造方法的核心作用是初始化新创建的对象,它在 new 表达式执行时被自动调用,负责为对象分配初始状态——不是“给对象起名字”,也不是“定义类的行为”,而是确保每个实例在诞生那一刻就处于可用、一致的状态。
构造方法被调用的唯一时机:new 实例化过程
Java 中构造方法不会被显式调用(不能写 obj.ConstructorName()),也不参与继承链的自动调用(子类不自动调用父类构造方法),它只响应 new 操作:
- 每次用
new MyClass()创建对象时,JVM 会查找匹配参数的构造方法并执行 - 若未定义任何构造方法,编译器自动插入一个无参、空体的默认构造方法
- 一旦定义了任意构造方法(哪怕只有一个带参的),默认构造方法就不再存在——这是新手最常见的空指针或编译报错源头
构造方法重载:靠参数列表区分,不能靠返回类型
Java 允许一个类有多个构造方法,但必须满足重载规则:方法名相同(即类名)、参数个数或类型不同。返回类型无关(构造方法本就没有返回类型,连 void 都不能写):
public class Person {
private String name;
private int age;
public Person() { // 无参构造
this.name = "unknown";
this.age = 0;
}
public Person(String name) { // 仅 name
this(name, 0);
}
public Person(String name, int age) { // 全参构造,调用 this(...) 必须是第一行
this.name = name;
this.age = age;
}
}
注意:this(...) 调用必须是构造方法的第一条语句;若误写成第二行,编译直接失败。
立即学习“Java免费学习笔记(深入)”;
为什么 super() 或 this() 必须是首行?
这是 JVM 对对象创建顺序的硬性约束:父类部分必须先完成初始化,才能执行子类逻辑。所以:
- 若子类构造方法没显式写
super(...)或this(...),编译器自动插入super() - 但如果父类没有无参构造方法,而子类又没显式调用
super(…),编译就会报错:Constructor Xxx in class Yyy cannot be applied to given types -
this(...)和super(...)不能共存于同一个构造方法中
构造方法里不该做什么?
它不是普通方法,设计初衷是“安全地建立对象初始状态”,因此要避开几类高风险操作:
- 避免在构造方法中调用可被子类重写的方法(
protected或public非final方法),此时子类字段可能还未初始化,导致null或默认值被使用 - 避免在构造中启动线程、打开文件、发起网络请求——这些操作可能失败,而构造方法无法用
throws声明受检异常(除非你声明,但调用方几乎无法优雅处理) - 避免将
this引用泄露出去(如注册监听、放入静态集合),因为此时对象尚未构造完成,其他线程可能看到半初始化状态
真正棘手的地方往往不在语法,而在构造时机与对象生命周期的耦合:一个看似简单的 new,背后牵扯的是内存分配、字段初始化、父类链执行、重写方法调用顺序——稍有不慎,就是隐匿的竞态或 NPE。






