构造方法的核心作用是对象创建时自动初始化,确保其处于可用合规状态;它不返回对象,只负责填值和检查,且必须与类名完全一致、无返回类型、不可用static等修饰。
它不是用来“返回对象”的(new 才干这事),而是确保每个新对象一出生就处于可用、合规的状态。比如 Person 类要求姓名不能为空,年龄必须在 0–150 之间——这些校验和赋值逻辑,就该写在构造方法里,而不是靠后续一个个调用 setName() 或 setAge() 去补。
private String name)若未在构造方法中显式赋值,会按类型取默认值(null、0、false),但这往往不是业务想要的初始态IllegalArgumentException),阻止非法对象被创建出来错一个字符、多一个 void、少一个参数,编译器就直接报错,没有商量余地。
public Person() {} ✅,public person() {} ❌(变成普通方法)void 都不行;写了就不是构造方法,而是同名的普通方法static、final、abstract 等修饰——这些修饰符与“每次 new 都要执行一次”的语义冲突public/protected/private)可选,但通常设为 public;设为 private 时,只能被本类内部
new Person() 突然编译失败?因为 Java 只在**你完全没写任何构造方法时**,才悄悄补一个无参的默认构造方法(public Person() {})。一旦你写了哪怕一个带参构造,这个“默认补丁”就立刻失效。
public class Person {
private String name;
private int age;
// 你写了这个 → 默认无参构造方法立即消失
public Person(String name) {
this.name = name;
}
}
// 下面这行代码编译报错:Cannot resolve constructor 'Person()'
Person p = new Person();
private,再配一个静态工厂方法重载本身很简单(参数个数/类型/顺序不同即可),但实际用错的地方集中在“this 调用链”和“初始化顺序”上。
this(...) 调用彼此,但必须是第一行语句this(...) 是调用本类其他构造方法,super(...) 是调用父类构造方法——二者不能共存于同一构造方法中this.init()),因为此时子类字段还未初始化,可能读到 null 或默认值最易被忽略的一点:构造方法不参与多态,也不会被继承。子类实例化时,JVM 会先走完父类构造方法(隐式或显式调用 super()),再执行子类构造体——这个链条一旦断裂(比如父类只有私有构造、或没写无参构造而子类又没显式 super(...)),编译直接失败。