美文网首页
一个Java反射常用方法的工具类

一个Java反射常用方法的工具类

作者: 吃板栗的猫 | 来源:发表于2019-08-24 20:58 被阅读0次

简介

反射是一个很强大的工具,能够在程序运行时动态的获取这个类中我们想获取到的信息,包括所有的构造器、方法、字段;
这里先写一个上述功能的一个小工具类,输入一个类名,然后输出类中所有的方法和构造器的签名,以及域,包括修饰关键字;
反射的功能当然不止这些,后面会继续完善;

用到的方法

Class.forName("class name");
返回类名的class对象;

class.getSuperClass();
返回class所继承的父类, 如果是Object则返回null;

class.getDeclaredConstructors();
返回这个对象的所有构造器, 是一个Construtor数组;

class.getDeclaredMethods();
返回这个对象所有方法, 是一个Method数组, 但是不包括由父类继承的方法;

class.getDeclaredFields();
返回一个Field数组, 数组包含这个类全部的域, 如果这个Class对象描述的是基本类型那么数组长度是0;

class.getModifiers();
返回这个对象的修饰符属性值;

代码示例

public class ReflectionTest {
    public static void main(String[] args) {
        try {
            // todo 这里的className为了方便展示,所以写死
            String className ;
            className = "java.util.Date";
            Class cl = Class.forName(className);
            Class superclass = cl.getSuperclass();
            String clModifier = Modifier.toString(cl.getModifiers());
            if (clModifier.length() > 0) {
                System.out.print(clModifier + " ");
            }
            System.out.print("class " + className);
            if (superclass != null && superclass != Object.class) {
                System.out.print(" extends " + superclass.getName());
            }
            System.out.print("\n{\n");
            printConstrutors(cl);
            System.out.println();
            printMethods(cl);
            System.out.println();
            printFields(cl);
            System.out.println("}");
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

    public static void printConstrutors(Class cl) {
            Constructor[] declaredConstructors = cl.getDeclaredConstructors();
        for(Constructor c : declaredConstructors) {
            String name = c.getName();
            System.out.print("  ");
            String modifiers = Modifier.toString(c.getModifiers());
            if (modifiers.length() > 0 ) {
                System.out.print(modifiers + " ");
            }
            System.out.print(name + "(");

            Class[] types = c.getParameterTypes();
            for (int i = 0; i < types.length; i++) {
                if (i > 0) {
                    System.out.print(", ");
                }
                System.out.print(types[i].getName());
            }
            System.out.println(");");
        }
    }

    public static void printMethods(Class cl) {
        Method[] methods = cl.getDeclaredMethods();
        for(Method m : methods){
            Class<?> returnType = m.getReturnType();
            String name = m.getName();
            System.out.print("  ");
            String modiferString = Modifier.toString(m.getModifiers());
            if (modiferString.length() > 0) {
                System.out.print(modiferString + " ");
            }

            System.out.print(returnType.getName() + "  " + name + "(");

            Class<?>[] parameterTypes = m.getParameterTypes();
            for (int i = 0; i < parameterTypes.length; i++) {
                if (i > 0) {
                    System.out.print(", ");
                }
                System.out.print(parameterTypes[i].getName());
            }
            System.out.println(");");
        }
    }

    public static void printFields(Class cl) {
        Field[] declaredFields = cl.getDeclaredFields();
        for (Field f : declaredFields) {
            Class<?> type = f.getType();
            String name = f.getName();
            System.out.print("  ");
            String modifiers = Modifier.toString(f.getModifiers());
            if (modifiers.length() > 0) {
                System.out.print(modifiers + "  ");
            }
            System.out.println(type.getName() + "  " + name + ";");
        }
    }
}

输出结果

public class java.util.Date
{
  public java.util.Date(int, int, int, int, int, int);
  public java.util.Date(java.lang.String);
  public java.util.Date();
  public java.util.Date(long);
  public java.util.Date(int, int, int);
  public java.util.Date(int, int, int, int, int);

  public boolean  after(java.util.Date);
  public boolean  before(java.util.Date);
  public boolean  equals(java.lang.Object);
  public java.lang.String  toString();
  public int  hashCode();
  public java.lang.Object  clone();
  public int  compareTo(java.util.Date);
  public volatile int  compareTo(java.lang.Object);
  private void  readObject(java.io.ObjectInputStream);
  private void  writeObject(java.io.ObjectOutputStream);
  private final sun.util.calendar.BaseCalendar$Date  normalize();
  private final sun.util.calendar.BaseCalendar$Date  normalize(sun.util.calendar.BaseCalendar$Date);
  public static long  parse(java.lang.String);
  public int  getDate();
  public static java.util.Date  from(java.time.Instant);
  public long  getTime();
  public void  setTime(long);
  public static long  UTC(int, int, int, int, int, int);
  private static final java.lang.StringBuilder  convertToAbbr(java.lang.StringBuilder, java.lang.String);
  private final sun.util.calendar.BaseCalendar$Date  getCalendarDate();
  private static final sun.util.calendar.BaseCalendar  getCalendarSystem(long);
  private static final sun.util.calendar.BaseCalendar  getCalendarSystem(sun.util.calendar.BaseCalendar$Date);
  private static final sun.util.calendar.BaseCalendar  getCalendarSystem(int);
  public int  getDay();
  public int  getHours();
  private static final synchronized sun.util.calendar.BaseCalendar  getJulianCalendar();
  static final long  getMillisOf(java.util.Date);
  public int  getMinutes();
  public int  getMonth();
  public int  getSeconds();
  private final long  getTimeImpl();
  public int  getTimezoneOffset();
  public int  getYear();
  public void  setDate(int);
  public void  setHours(int);
  public void  setMinutes(int);
  public void  setMonth(int);
  public void  setSeconds(int);
  public void  setYear(int);
  public java.lang.String  toGMTString();
  public java.time.Instant  toInstant();
  public java.lang.String  toLocaleString();

  private static final  sun.util.calendar.BaseCalendar  gcal;
  private static  sun.util.calendar.BaseCalendar  jcal;
  private transient  long  fastTime;
  private transient  sun.util.calendar.BaseCalendar$Date  cdate;
  private static  int  defaultCenturyStart;
  private static final  long  serialVersionUID;
  private static final  [Ljava.lang.String;  wtb;  
  private static final  [I  ttb;
}

Process finished with exit code 0

作用

得到这个类的所有构造器、方法、域,方便进行后续的逻辑处理;
反射的功能当然远远不止如此, 后面会继续完善;
欢迎大佬们给出不足或者更好的建议;

相关文章

  • 反射

    Class类与Java反射 通过反射可访问的主要描述信息 访问构造方法 Constructor类的常用方法 Mod...

  • 反射

    常用方法 反射得到数组 java.lang.Class类的getGenericInterfaces()方法用于获取...

  • 一个Java反射常用方法的工具类

    简介 反射是一个很强大的工具,能够在程序运行时动态的获取这个类中我们想获取到的信息,包括所有的构造器、方法、字段;...

  • 反射工具类

    在做Android加固的时候经常用到反射,然后我就从网上复制了一个反射工具类总共包含下面6个方法调用类的静态方法调...

  • Java反射基础API应用

    java 反射常用方法概览 脑图地址 测试类 获取类的三种方法 通过class可以直接调用newInstance,...

  • Java基础之反射

    Java-Reflect Class类的使用 方法的反射 成员变量的反射 构造函数的反射 Java类加载机制 一、...

  • JAVA-Reflect

    一、Class类的使用 二、Java动态加载类 三、Java获取方法信息 四、Java方法的反射

  • Java反射

    一. Class类 二. Java动态加载类 三. Java获取方法信息 四. Java方法反射的基本操作

  • java 反射获取类对象的三种方式

    Java反射经常用到的就是获取对象中的属性,那么Java获取类对象就是必不可少的啦! Java实体类: 通过反射获...

  • java 利用反射动态调用自身方法及父类方法实例

    demo类: 反射工具类:ReflectionUtil.java父类:Animal.java子类1:Dog.jav...

网友评论

      本文标题:一个Java反射常用方法的工具类

      本文链接:https://www.haomeiwen.com/subject/mznqectx.html