




new 是 Java 创建对象最直接可控的方式,触发完整生命周期:分配内存→初始化字段→执行构造方法→返回引用;需注意语法规范、异常处理及构造方法逻辑完整性。
Java 中绝大多数对象通过 new 调用构造方法完成实例化,这是最基础也最可控的途径。它会触发完整的对象生命周期:分配堆内存 → 初始化字段(默认值)→ 执行构造方法体 →

常见错误现象包括:NullPointerException(忘记 new 直接调用方法)、NoClassDefFoundError(类路径缺失但编译期未报错)、构造方法抛异常导致对象未完全构建。
MyClass obj = new MyClass();,不能省略括号(即使无参构造)new MyClass() 会编译失败this(...) 或 super(...),必须是第一行语句JDK 9 开始,Class.newInstance() 被标记为 @Deprecated,因为它无法处理带参构造、访问控制异常不明确,且绕过安全检查。现在应使用 Constructor 对象显式调用。
典型使用场景:框架(如 Spring、JUnit)需要在运行时根据类名创建对象;测试中模拟不同构造参数组合。
clazz.getDeclaredConstructor(String.class) 后要调用 setAccessible(true) 才能访问 private 构造方法int 和 Integer 不自动转换,否则抛 NoSuchMethodException
InvocationTargetException,需用 e.getCause() 提取原始异常clone() 不属于“根据类创建对象”,而是基于已有对象生成副本。它不调用任何构造方法,也不执行初始化逻辑,仅复制字段值(引用类型只复制地址)。
容易踩的坑在于误以为它等价于 new:比如单例模式下用 clone() 破坏了唯一性;或未重写 clone() 导致 CloneNotSupportedException。
Cloneable 接口,否则调用 clone() 抛 CloneNotSupportedException
super.clone(),并手动深拷贝可变引用字段Object,避免强制转型ObjectInputStream.readObject() 和 Unsafe.allocateInstance() 都能绕过构造方法获得对象实例,但它们用途极窄,且有明确限制。
反序列化要求类实现 Serializable,且依赖字节流内容;Unsafe 是内部 API,JDK 9+ 默认禁止反射访问,需加 JVM 参数才能启用,仅限高性能框架(如 Netty、Lombok)底层使用。
Unsafe.allocateInstance() 创建的对象字段全是默认值(null、0、false),连 static 块都不执行new,因为缺少业务逻辑初始化,强行使用易引发 NPE 或逻辑错误