博客
关于我
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、HBase 和 Elasticsearch:特点与区别详解
    查看>>
    MySQL、Redis高频面试题汇总
    查看>>
    MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
    查看>>
    mysql一个字段为空时使用另一个字段排序
    查看>>
    MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
    查看>>
    MYSQL一直显示正在启动
    查看>>
    MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
    查看>>
    MySQL万字总结!超详细!
    查看>>
    Mysql下载以及安装(新手入门,超详细)
    查看>>
    MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
    查看>>
    MySQL不同字符集及排序规则详解:业务场景下的最佳选
    查看>>
    Mysql不同官方版本对比
    查看>>
    MySQL与Informix数据库中的同义表创建:深入解析与比较
    查看>>
    mysql与mem_细说 MySQL 之 MEM_ROOT
    查看>>
    MySQL与Oracle的数据迁移注意事项,另附转换工具链接
    查看>>
    mysql丢失更新问题
    查看>>
    MySQL两千万数据优化&迁移
    查看>>
    MySql中 delimiter 详解
    查看>>
    MYSQL中 find_in_set() 函数用法详解
    查看>>
    MySQL中auto_increment有什么作用?(IT枫斗者)
    查看>>