构造方法是初始化新对象的特殊成员方法,由new自动调用,负责赋初值、建状态、分配资源;若未定义任何构造方法,编译器默认插入public无参构造,但一旦自定义任一构造方法,默认构造即消失。

构造方法是用来初始化新创建对象的特殊成员方法
它在 new 表达式执行时被自动调用,负责为对象的实例变量赋予初始值、建立内部状态、触发必要资源分配(如打开文件、连接数据库等)。没有构造方法,Java 无法完成对象的合法实例化——哪怕你没写,编译器也会悄悄补上一个无参默认构造方法。
不写构造方法时会发生什么
如果类中**完全没定义任何构造方法**,编译器会自动插入一个无参、空体、public 的默认构造方法。但只要写了任意一个构造方法(哪怕只是 private MyClass() {}),这个默认构造方法就立刻消失。
- 子类继承该类时,若子类构造方法里没显式调用
super(...),编译器会尝试插入super()—— 此时若父类已无无参构造方法,直接报错:Constructor not defined - 使用反射(如
Class.newInstance()或Constructor.newInstance())创建实例时,若依赖无参构造方法,也会失败 - JSON 库(如 Jackson)反序列化时默认走无参构造 + setter,若无参构造被覆盖又未保留,会抛
InstantiationException
构造方法重载与 this() 调用的限制
一个类可以有多个构造方法,参数列表不同即构成重载。但要注意:this(...) 必须是构造方法的第一条语句,且只能出现一次;它用于复用本类其他构造逻辑,避免重复代码。
public class Person {
private String name;
private int age;
public Person(String name) {
this(name, 0); // ✅ 合法:第一行,调用本类另一个构造方法
}
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public Person() {
this("unknown"); // ✅ 也可以这样链式调用
}
}
-
this(...)和super(...)不能共存于同一个构造方法中 - 不能在普通方法里调用
this(...),也不能在静态上下文中使用 - 如果构造方法里做了耗时操作(如网络请求、大对象初始化),会影响所有
new调用的性能,应考虑延迟加载或工厂模式解耦
构造方法里不适合做哪些事
构造方法本质是“对象诞生的临界点”,此时对象尚未完全构建完毕,对外不可见,但内部状态可能不一致。以下行为容易引发问题:
立即学习“Java免费学习笔记(深入)”;
- 调用可被子类重写的非
final实例方法:子类方法可能访问到未初始化的字段,返回null或默认值(如0、false) - 将
this引用泄露出去(如注册监听器、放入全局容器、启动线程),可能导致其他线程看到半初始化的对象 - 抛出未声明的受检异常(
Exception),迫使所有调用方强制处理,破坏封装性;更推荐用运行时异常(IllegalArgumentException)表达非法参数 - 执行阻塞 I/O 或长时间计算,让对象创建变成性能瓶颈,且难以超时控制
真正复杂的初始化逻辑,更适合移到工厂方法、构建器(Builder)或初始化后回调(如 Spring 的 @PostConstruct)中处理。










