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

简介

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

用到的方法

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

作用

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

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 这是16年5月份编辑的一份比较杂乱适合自己观看的学习记录文档,今天18年5月份再次想写文章,发现简书还为我保存起的...
    Jenaral阅读 2,869评论 2 9
  • 反射库提供了一个非常丰富且精心设计的工具集,以便能够动态编写能够操纵Java代码的程序。这项功能被大量应用于Jav...
    Steven1997阅读 641评论 0 2
  • 整理来自互联网 1,JDK:Java Development Kit,java的开发和运行环境,java的开发工具...
    Ncompass阅读 1,559评论 0 6
  • 1.import static是Java 5增加的功能,就是将Import类中的静态方法,可以作为本类的静态方法来...
    XLsn0w阅读 1,268评论 0 2
  • 一:java概述: 1,JDK:Java Development Kit,java的开发和运行环境,java的开发...
    慕容小伟阅读 1,845评论 0 10