java反射
系列文章目录
第一章 万事万物皆对象
第二章 java构造器
第三章 java访问权限
第四章 java初始化
第五章 java继承
第六章 java重载与重写
第七章 java接口和抽象类
第八章 java数组
第九章 java内部类
第十章 java时间操作
第十一章 final关键字
第十二章 java字符串
第十三章 java异常
第十四章 java泛型
第十五章 java IO操作
第十六章 java NIO操作
第十七章 java zip压缩
第十八章 java反射
第十九章 java反射之Type接口
第二十章 java8流式操作
第二十一章 java8函数式编程
原文链接 https://zhhll.icu/2020/java基础/反射/1.反射/
反射
Java提供反射来在运行时状态下动态的获取类的属性、方法等信息,在框架中很多地方都应用到了反射
反射的操作
获取Class对象
获取Class对象的四种方式
// 第一种
Class<Person> clazz = Person.class;
// 第二种
Person person = new Person();
Class clazz1 = person.getClass();
// 第三种
String className = "com.zhanghe.study.reflect.Person";
Class clazz2 = Class.forName(className);
// 第四种 使用类加载器
ClassLoader classLoader = TestClass.class.getClassLoader();
Class clazz3 = classLoader.loadClass(className);
获取构造器
Class clazz = TestConstructor.class;
Constructor[] constructors = clazz.getConstructors();
System.out.println("=========clazz.getConstructors()====只能获取到公有的构造器");
for(Constructor constructor : constructors){
System.out.println(constructor);
}
System.out.println("*****************");
System.out.println("=========clazz.getConstructor()=====获取公有无参构造器");
Constructor constructor = clazz.getConstructor();
System.out.println(constructor);
System.out.println("*****************");
System.out.println("=========clazz.getDeclaredConstructors()=====获取所有构造器(包括私有、受保护、默认、公有)");
Constructor[] declaredConstructors = clazz.getDeclaredConstructors();
for(Constructor declaredConstructor : declaredConstructors){
System.out.println(declaredConstructor);
}
System.out.println("*****************");
System.out.println("=========clazz.getDeclaredConstructor()====获取指定参数类型的构造器");
Constructor declaredConstructor = clazz.getDeclaredConstructor(String.class);
System.out.println(declaredConstructor);
System.out.println("*****************");
获取属性
System.out.println("======getFields===========");
// 获取所有的属性 只能获取到该类和父类中public的
Field[] fields = clazz.getFields();
for (Field f : fields){
System.out.println(f.getName());
}
System.out.println("======getDeclaredFields===========");
// 获取所有的属性 本类中声明的所有的属性都可以获取到,不可以获取到父类的
Field[] declaredFields = clazz.getDeclaredFields();
for (Field f : declaredFields){
// 获取权限修饰符
int i = f.getModifiers();
String m = Modifier.toString(i);
System.out.println("Modifier:"+m);
// 获取属性类型
Class type = f.getType();
System.out.println("type:"+type.getTypeName());
// 获取属性名
System.out.println("name:"+f.getName());
}
获取方法
System.out.println("======getMethods===========");
// 获取本类和父类中所有的public方法
Method[] methods = clazz.getMethods();
for(Method m : methods){
System.out.println(m.getName());
}
System.out.println("======getDeclaredMethods===========");
// 获取本类中所有的方法,包括私有方法 父类的无法获取
Method[] declaredMethods = clazz.getDeclaredMethods();
for(Method m : declaredMethods){
// 获取注解
Annotation[] annotations = m.getAnnotations();
// 权限修饰符
System.out.println("Modifier:"+Modifier.toString(m.getModifiers()));
// 返回值类型
Class reture = m.getReturnType();
// 形参列表
Class[] params = m.getParameterTypes();
// 方法名
System.out.println(m.getName());
// 异常类型
Class[] exceptions = m.getExceptionTypes();
}
获取父类信息
// 获取父类
Class superClass = clazz.getSuperclass();
// 获取带泛型的父类
Type superType = clazz.getGenericSuperclass();
// 获取父类的泛型
if(superType instanceof ParameterizedType){ // 如果存在泛型
Type[] actualTypeArguments = ((ParameterizedType) superType).getActualTypeArguments();
}
获取接口
// 获取实现的接口
Class[] interfaces = clazz.getInterfaces();
获取包
// 获取所在的包
Package aPackage = clazz.getPackage();
获取注解
// 获取注解
Annotation[] annotations = clazz.getAnnotations();
反射为属性赋值
// 通过反射创建person实例
Person person = clazz.newInstance();
// 通过反射获取类的age属性,并赋值
Field field = clazz.getDeclaredField("age");
field.setAccessible(true);
field.set(person,20);
反射执行方法
// 通过反射获取方法,并调用
Method method = clazz.getMethod("display");
method.invoke(person);
本文来自博客园,作者:拾光师,转载请注明原文链接:https://www.cnblogs.com/life-time/p/17864409.html 个人博客-> https://zhhll.icu
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~