Java反射机制允许运行时动态获取类信息、创建对象、调用方法和访问字段,核心是绕过编译期绑定;通过Class对象(类名.class、getClass()、Class.forName)启动,支持动态实例化、方法调用及私有成员操作(需setAccessible(true)),广泛应用于框架(Spring、MyBatis)、JSON序列化、测试Mock和插件系统等场景。
Java反射机制让你在运行时获取类的信息、创建对象、调用方法、访问字段,哪怕这些类在编译时还不知道。核心在于绕过“编译期绑定”,实现动态操作——不是写死的 new、方法名、属性名,而是用字符串或 Class 对象来驱动。
反射一切操作都始于 Class 对象。获取方式有三种:
String.class,最常用,不触发初始化"abc".getClass(),适用于已有实例Class.forName("java.util.ArrayList"),会触发类的静态初始化,常用于配置驱动、插件加载拿到 Class 后,就能跳过 new 关键字创建实例:
clazz.ge
tDeclaredConstructor().newInstance()
getDeclaredConstructor(String.class, int.class) 获取构造器,再 newInstance("hello", 123)
getMethod("methodName", paramTypes...) 或 getDeclaredMethod(...)(后者可访问 private 方法),然后 method.invoke(obj, args...)
注意:getDeclaredXXX 系列能访问 private 成员,但需先调用 setAccessible(true) 绕过访问检查(JDK 9+ 在模块化下受限制)。
字段操作类似方法:
getField("publicField")(仅 public)或 getDeclaredField("privateField")
field.set(obj, newValue)
field.get(obj)
setAccessible(true) 才能操作非 public 字段比如给一个 private 的 name 字段赋值:field.set(instance, "张三");
反射不是炫技工具,它解决的是“不确定性”问题:
基本上就这些。用好反射的关键是理解“什么时候必须动态”,而不是为了用而用。性能开销和安全性(如 setAccessible)要心里有数,生产环境慎用 private 成员反射。