博客
关于我
Java反射机制详解
阅读量:804 次
发布时间:2019-03-25

本文共 3325 字,大约阅读时间需要 11 分钟。

反射机制

反射机制是Java语言的一个核心功能,允许程序在运行时对类、对象进行动态操作。以下是对反射机制的详细解析。

一、反射机制的定义

反射机制允许在运行时对任意类进行操作,具体包括:

  • 获取类的所有属性和方法。
  • 调用任意对象的方法或获取属性值。
  • 动态构造类对象。

这种动态性质使反射机制在代码调试、动态 proxy 创建以及反转工程等场景中至关重要。

二、反射机制的功能

反射机制的主要功能包括:

  • 判断对象所属的类。
  • 构造指定类的对象。
  • 获取类的成员变量和方法。
  • 调用对象的任意方法。
  • 生成动态代理。

三、获取Class对象的方式

获取Class对象可以通过以下方法:

  • 使用类文字(如MyClass.class)。
  • 使用getClass()方法获取对象的类。
  • 使用forName(String className)方法动态加载类。

例如:

Class c1 = MyClass.class;Class c2 = new MyClass().getClass();Class c3 = Class.forName("reflect.MyClass");

四、Class对象的信息获取

通过Class对象可以获取类的详细信息:

  • 类名和包名getSimpleName()获取简单类名,getName()获取完整类名。
  • 修饰符getModifiers()返回修饰符整数值,可通过Modifier.toString()转换为文本形式。
  • 超类和接口getSuperclass()获取超类,getInterfaces()获取实现的接口。

例如:

Class c = MyClass.class;System.out.println("简单类名:" + c.getSimpleName());System.out.println("完整类名:" + c.getName());Package p1 = c.getPackage();System.out.println("包名:" + p1.getName());int modifiers = c.getModifiers();String mod = Modifier.toString(modifiers);System.out.println("修饰符:" + mod);Class[] interfaces = c.getInterfaces();for (Class in : interfaces) {    System.out.println(in);}

五、获取类的字段

通过Field类获取字段:

  • 获取所有字段:getFields()getDeclaredFields()
  • 根据字段名获取字段:getField(String name)getDeclaredField(String name)

例如:

Class c = MyClass.class;Field[] fields1 = c.getDeclaredFields();for (Field f : fields1) {    int mod = f.getModifiers();    String modifiers = Modifier.toString(mod);    Class type = f.getType();    String typeName = type.getSimpleName();    System.out.println(modifiers + " " + typeName + " " + f.getName());}Field[] fields2 = c.getFields();for (Field f : fields2) {    int mod = f.getModifiers();    String modifiers = Modifier.toString(mod);    Class type = f.getType();    String typeName = type.getSimpleName();    System.out.println(modifiers + " " + typeName + " " + f.getName());}

六、获取类的构造函数

通过Constructor类获取构造函数:

  • 获取所有构造函数:getConstructors()getDeclaredConstructors()
  • 根据参数类型获取特定构造函数:getConstructor(Class... parameterTypes)getDeclaredConstructor(Class... parameterTypes)

例如:

Class c = MyClass.class;Constructor[] constructors = c.getConstructors();for (Constructor constructor : constructors) {    String modifiers = getModifiers(constructor);    String constructorName = constructor.getName();    // 输出构造函数信息}

七、获取类的实例方法

通过Method类获取方法:

  • 获取所有方法:getMethods()getDeclaredMethods()
  • 根据方法名和参数类型获取特定方法:getMethod(String name, Class... parameterTypes)getDeclaredMethod(String name, Class... parameterTypes)

例如:

Class c = MyClass.class;Method[] methods = c.getDeclaredMethods();for (Method m : methods) {    System.out.println("方法名:" + m.getName());    System.out.println("修饰符:" + getModifiers(m));    // 输出其他方法信息}

八、通过Class对象创建对象

通过反射创建对象的步骤:

  • 获取构造函数。
  • 使用newInstance()创建对象或使用invoke()调用带参数的构造函数。
  • 例如:

    Class myClass = MyClass.class;MyClass obj = myClass.newInstance();Constructor constructor = myClass.getConstructor(int.class, String.class);MyClass obj = constructor.newInstance(1, "abc");

    九、数组操作

    反射也支持对数组进行操作:

    • 获取数组信息:Array.getLength()Array.get()
    • 修改数组值和大小:Array.set()Array.newInstance()

    例如:

    int[] array = {1, 2, 3, 4, 5};Class demo = array.getClass().getComponentType();System.out.println("数组类型:" + demo.getName());System.out.println("数组长度:" + Array.getLength(array));System.out.println("数组的第一个元素:" + Array.get(array, 0));Array.set(array, 0, 100);System.out.println("修改后的数组第一个元素:" + Array.get(array, 0));

    通过以上方法,可以充分利用反射机制进行动态操作和灵活开发。

    转载地址:http://ivbyk.baihongyu.com/

    你可能感兴趣的文章
    Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
    查看>>
    mysql InnoDB数据存储引擎 的B+树索引原理
    查看>>
    mysql innodb通过使用mvcc来实现可重复读
    查看>>
    mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
    查看>>
    mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
    查看>>
    Mysql join原理
    查看>>
    MySQL Join算法与调优白皮书(二)
    查看>>
    Mysql order by与limit混用陷阱
    查看>>
    Mysql order by与limit混用陷阱
    查看>>
    mysql order by多个字段排序
    查看>>
    MySQL Order By实现原理分析和Filesort优化
    查看>>
    mysql problems
    查看>>
    mysql replace first,MySQL中处理各种重复的一些方法
    查看>>
    MySQL replace函数替换字符串语句的用法(mysql字符串替换)
    查看>>
    mysql replace用法
    查看>>
    Mysql Row_Format 参数讲解
    查看>>
    mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
    查看>>
    MySQL Server 5.5安装记录
    查看>>
    mysql server has gone away
    查看>>
    mysql slave 停了_slave 停止。求解决方法
    查看>>