构造方法无返回类型且名须与类名一致;super()和this()仅限首行调用;子类不继承父类构造方法;抽象类可有构造方法,接口不可;构造方法在new时由JVM自动调用,用于对象初始化。

构造方法没有返回值类型声明
构造方法名字必须和类名完全一致,且不能写 void 或任何其他返回类型(包括 void 本身)。写了就变成普通方法,JVM 不会把它当构造器用。比如:
public class Person {
public Person() { } // ✅ 正确的构造方法
public void Person() { } // ❌ 编译通过但不是构造方法,是普通方法
}
Java 编译器靠「无返回类型 + 名字匹配类名」这两个条件识别构造方法。漏掉任一条件,它就只是个长得像构造方法的普通方法。
super() 和 this() 只能在构造方法第一行调用
这是语法硬性限制:子类构造方法中若要显式调用父类构造器,必须用 super(...);同类中重载构造器调用必须用 this(...);且二者只能出现在第一行,且不能共存。
- 没写
super(),编译器自动插入super()(无参),前提是父类有无参构造器 - 父类只有带参构造器时,子类必须显式写
super(...),否则编译失败 -
this(...)调用后,本构造器其余代码才执行,常用于参数归一化处理
成员方法可以重写,构造方法不能被继承也不能被重写
构造方法只属于定义它的那个类,子类不会继承父类的构造方法。你看到子类“有”某个构造签名,那一定是自己写的,不是继承来的。
立即学习“Java免费学习笔记(深入)”;
这也意味着:
- 不能用
@Override标注构造方法(编译报错) - 不能在子类中靠“重写”来改变父类对象初始化逻辑,只能通过组合
super(...)控制初始化流程 - 抽象类可以有构造方法(供子类调用),但接口不能有(连
new都不支持)
构造方法执行时机和用途完全不同
成员方法是对象创建后、由程序员显式触发的行为;而构造方法只在 new 表达式执行时由 JVM 自动调用一次,核心任务是确保对象处于可用状态——比如初始化 final 字段、分配资源、校验必要参数。
常见误用:
- 在构造方法里调用可被重写的方法(如
this.init()),可能导致子类字段未初始化就被访问(因子类构造器还没执行) - 在构造方法里启动线程或注册监听器,此时对象可能尚未构建完成,外部已能访问该引用
- 把耗时操作(如网络请求、大文件读取)塞进构造方法,导致
new阻塞且无法异常隔离
这些都不是语法错误,但会埋下隐性 bug,而且很难调试——因为堆栈里只显示 new,看不出问题出在哪个构造逻辑里。










