Java反射(四)反射获取类的结构信息

简介: 介绍了Constructor Method Field Class的API

四.反射获取类的结构信息

1.第一组:java.lang.Class类

1.getName:获取全类名2.getSimpleName:获取简单类名3.getFields:获取所有publicf修饰的属性,包含本类以及父类的4.getDeclaredFields:获取本类中所有属性5.getMethods:获取所有public修饰的方法,包含本类以及父类的6.getDeclaredMethods:获取本类中所有方法7.getConstructors:获取所有public修饰的构造器,包含本类8.getDeclaredConstructors:获取本类中所有构造器9.getPackage:以Package]形式返回包信息10.getSuperClass:以Class形式返回父类信息11.getInterfaces:以Class[]形式返回接口信息12.getAnnotations:以Annotation[]形式返回注解信息

/**

* @author LeeZhi

* @version 1.0

* 演示如何通过反射获取类的结构信息

*/

publicclassReflectionUtils {

   publicstaticvoidmain(String[] args) {

   }

   //第一组方法API

   @Test

   publicvoidapi_01() throwsClassNotFoundException {

       /**

        * 1.getName:获取全类名

        * 2.getSimpleName:获取简单类名

        * 3.getFields:获取所有publicf修饰的属性,包含本类以及父类的

        * 4.getDeclaredFields:获取本类中所有属性

        * 5.getMethods:获取所有public修饰的方法,包含本类以及父类的

        * 6.getDeclaredMethods:获取本类中所有方法

        * 7.getConstructors:获取本类所有public修饰的构造器

        * 8.getDeclaredConstructors:获取本类中所有构造器

        * 9.getPackage:以Package]形式返回包信息

        * 10.getSuperClass:以Class形式返回父类信息

        * 11.getInterfaces:以Class[]形式返回接口信息

        * 12.getAnnotations:以Annotation[]形式返回注解信息

        */

       //1.得到Class对象

       Class<?>personCls=Class.forName("com.gbx.reflection.Person");

       System.out.println(personCls.getName());

       System.out.println(personCls.getSimpleName());

       Field[] fields=personCls.getFields();

       for (Fieldfield : fields) {

           System.out.println("本类以及父类的属性:"+field.getName());

       }

       Field[] declaredFields=personCls.getDeclaredFields();

       for (FielddeclaredField : declaredFields) {

           System.out.println("本类所有属性:"+declaredField.getName());

       }

       Method[] methods=personCls.getMethods();

       for (Methodmethod : methods) {

           System.out.println("本类及父类的方法:"+method.getName());

       }

       Method[] declaredMethods=personCls.getDeclaredMethods();

       for (MethoddeclaredMethod : declaredMethods) {

           System.out.println("本类所有方法:"+declaredMethod.getName());

       }

       Constructor<?>[] constructors=personCls.getConstructors();

       for (Constructor<?>constructor : constructors) {

           System.out.println("本类的构造器:"+constructor.getName());

       }

       Constructor<?>[] declaredConstructors=personCls.getDeclaredConstructors();

       for (Constructor<?>declaredConstructor : declaredConstructors) {

           System.out.println("本类中所有构造器:"+declaredConstructor.getName());

       }

       System.out.println(personCls.getPackage());

       Class<?>superclass=personCls.getSuperclass();

       System.out.println("父类的class对象"+superclass);

       Class<?>[] interfaces=personCls.getInterfaces();

       for (Class<?>anInterface : interfaces) {

           System.out.println("接口信息:"+anInterface);

       }

       Annotation[] annotations=personCls.getAnnotations();

       for (Annotationannotation : annotations) {

           System.out.println("注解信息:"+annotation);

       }

   }

}

classA{

   publicStringhobby;

   publicvoidhi(){

   }

   publicA() {

   }

}

interfaceIA{

}

interfaceIB{

}

classPersonextendsAimplementsIA,IB{

   //属性

   publicStringname;

   protectedintage;

   Stringjob;

   privatedoublesal;

   publicPerson() {

   }

   publicPerson(Stringname) {

       this.name=name;

   }

   privatePerson(Stringname,intage){

   }

   //方法

   publicvoidm1(){

   }

   protectedvoidm2(){

   }

   voidm3(){

   }

   privatevoidm4(){

   }

}

2.第二组:java.lang.reflect.Field类

1.getModifiers:以int形式返回修饰符[说明:默认修饰符是0,public是1,private是2,protected是4,static是8,final是16]   public(1)+static (8)=92.getType:以Class形式返回类型3.getName:返回属性名

   @Test

   publicvoidapi_02() throwsClassNotFoundException {

       //1.得到Class对象

       Class<?>personCls=Class.forName("com.gbx.reflection.Person");

       Field[] declaredFields=personCls.getDeclaredFields();

       for (FielddeclaredField : declaredFields) {

           System.out.println("本类所有属性:"+declaredField.getName()

                   +"该属性的修饰值:"+declaredField.getModifiers()

                   +"该属性的类型"+declaredField.getType());

       }

   }

3.第三组:java.lang.reflect.Method类

1.getModifiers:以int形式返回修饰符[说明:默认修饰符是0,public是1,private是2,protected是4,static是8,final是16]2.getReturnType:以Classj形式获取返回类型3.getName:返回方法名4.getParameterTypes:以Class[]返回参数类型数组

Method[] declaredMethods=personCls.getDeclaredMethods();
for (MethoddeclaredMethod : declaredMethods) {
System.out.println("本类所有方法:"+declaredMethod.getName()
+"该方法的访问修饰符"+declaredMethod.getModifiers()
+"该方法返回类型"+declaredMethod.getReturnType());
//输出当前这个方法的形参数组情况Class<?>[] parameterTypes=declaredMethod.getParameterTypes();
for (Class<?>parameterType : parameterTypes) {
System.out.println("该方法形参类型:"+parameterType);
            }
        }


4.第四组:java.lang.reflect.Constructor类

1.getModifiers:以int形式返回修饰符2.getName:返回构造器名(全类名)3.getParameterTypes:以Class[]返回参数类型数组

Constructor<?>[] declaredConstructors=personCls.getDeclaredConstructors();
for (Constructor<?>declaredConstructor : declaredConstructors) {
System.out.println("本类中所有构造器:"+declaredConstructor.getName());
Class<?>[] parameterTypes=declaredConstructor.getParameterTypes();
for (Class<?>parameterType : parameterTypes) {
System.out.println("该构造器的形参类型:"+parameterType);
            }
        }
目录
相关文章
|
2天前
|
监控 JavaScript 数据可视化
建筑施工一体化信息管理平台源码,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
智慧工地云平台是专为建筑施工领域打造的一体化信息管理平台,利用大数据、云计算、物联网等技术,实现施工区域各系统数据汇总与可视化管理。平台涵盖人员、设备、物料、环境等关键因素的实时监控与数据分析,提供远程指挥、决策支持等功能,提升工作效率,促进产业信息化发展。系统由PC端、APP移动端及项目、监管、数据屏三大平台组成,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
|
2月前
|
Java 开发者
在 Java 中,一个类可以实现多个接口吗?
这是 Java 面向对象编程的一个重要特性,它提供了极大的灵活性和扩展性。
164 57
|
17天前
|
JSON Java Apache
Java基础-常用API-Object类
继承是面向对象编程的重要特性,允许从已有类派生新类。Java采用单继承机制,默认所有类继承自Object类。Object类提供了多个常用方法,如`clone()`用于复制对象,`equals()`判断对象是否相等,`hashCode()`计算哈希码,`toString()`返回对象的字符串表示,`wait()`、`notify()`和`notifyAll()`用于线程同步,`finalize()`在对象被垃圾回收时调用。掌握这些方法有助于更好地理解和使用Java中的对象行为。
|
15天前
|
Java 数据库连接 Spring
反射-----浅解析(Java)
在java中,我们可以通过反射机制,知道任何一个类的成员变量(成员属性)和成员方法,也可以堆任何一个对象,调用这个对象的任何属性和方法,更进一步我们还可以修改部分信息和。
|
2月前
|
SQL Java
使用java在未知表字段情况下通过sql查询信息
使用java在未知表字段情况下通过sql查询信息
42 8
|
2月前
|
存储 缓存 安全
java 中操作字符串都有哪些类,它们之间有什么区别
Java中操作字符串的类主要有String、StringBuilder和StringBuffer。String是不可变的,每次操作都会生成新对象;StringBuilder和StringBuffer都是可变的,但StringBuilder是非线程安全的,而StringBuffer是线程安全的,因此性能略低。
68 8
|
2月前
|
JSON Java 程序员
Java|如何用一个统一结构接收成员名称不固定的数据
本文介绍了一种 Java 中如何用一个统一结构接收成员名称不固定的数据的方法。
32 3
|
2月前
|
监控 Java
Java基础——反射
本文介绍了Java反射机制的基本概念和使用方法,包括`Class`类的使用、动态加载类、获取方法和成员变量信息、方法反射操作、以及通过反射了解集合泛型的本质。同时,文章还探讨了动态代理的概念及其应用,通过实例展示了如何利用动态代理实现面向切面编程(AOP),例如为方法执行添加性能监控。
|
5月前
|
Java 开发者
奇迹时刻!探索 Java 多线程的奇幻之旅:Thread 类和 Runnable 接口的惊人对决
【8月更文挑战第13天】Java的多线程特性能显著提升程序性能与响应性。本文通过示例代码详细解析了两种核心实现方式:Thread类与Runnable接口。Thread类适用于简单场景,直接定义线程行为;Runnable接口则更适合复杂的项目结构,尤其在需要继承其他类时,能保持代码的清晰与模块化。理解两者差异有助于开发者在实际应用中做出合理选择,构建高效稳定的多线程程序。
68 7
|
3月前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
47 3
下一篇
开通oss服务