Java构造方法必须与类名完全一致(大小写敏感),无返回类型,可重载;new对象时按固定顺序初始化;无显式构造方法时编译器自动添加无参构造,但一旦定义任一构造方法则默认无参构造消失;this()和super()必须位于构造方法首行且互斥。

构造方法必须和类名完全一致
Java中构造方法不是普通方法,它没有返回类型(连void都不能写),且名称必须严格等于所在类的类名——大小写敏感。一旦写成public void MyClass()或public MyClass2(),编译器就当它是普通方法,对象创建时根本不会调用它。
- 类名是
Person,构造方法就必须叫Person,不能是person或PersonBuilder - 如果类是
public class HTTPClient,构造方法名也必须是HTTPClient,不能写成HttpClient(哪怕只是首字母小写) - 构造方法可以重载,比如
Person()、Person(String name)、Person(String name, int age),但每个都得叫Person
new 之后发生了什么:初始化顺序不可跳过
执行new Person("Alice")时,JVM按固定顺序完成初始化,这个顺序直接影响字段值和逻辑结果:
- 先为所有实例字段分配内存并设默认值(
int→0,Object→null) - 然后执行父类的静态字段初始化和静态代码块(只在类首次加载时运行一次)
- 再执行本类的静态字段初始化和静态代码块
- 接着执行父类的非静态字段初始化和实例代码块
- 最后执行父类构造方法 → 本类非静态字段初始化和实例代码块 → 本类构造方法体
这意味着:如果在实例代码块里打印this.name,而name是在构造方法里才赋值的,那此时输出的是null,不是你预期的值。
不写构造方法时,编译器自动补的是无参构造方法
只要没显式定义任何构造方法,编译器会悄悄加一个public 类名()。但只要你写了任意一个构造方法(哪怕是有参的),这个默认无参构造就消失了。
立即学习“Java免费学习笔记(深入)”;
public class Config {
private String path;
// 没写任何构造方法 → 编译器自动加 public Config() {}
}
public class Service {
private String host;
public Service(String host) { this.host = host; }
// 此时 new Service() 会编译报错:constructor Service() is undefined
}
这点在继承中尤其关键:子类构造方法第一行默认调用super(),如果父类没有无参构造,又没显式写super(...),直接编译失败。
this(...) 和 super(...) 必须是构造方法的第一条语句
构造方法里若要调用本类其他构造方法(this(...))或父类构造方法(super(...)),它们必须出现在第一行,且二者不能共存。
-
this("default")后面不能再有super(),否则编译报错 - 想先做参数校验再转发?不行。得把校验逻辑提到调用方,或者改用工厂方法
- 常见错误:
if (name == null) throw new IllegalArgumentException(); this(name);→ 编译不通过,因为this()不在第一行
这种限制让构造逻辑变得“刚性”,很多实际场景下不得不把初始化拆到init()方法里,或改用构建器模式。










