1.获得Class对象

  1. Class<?>  classType  =  Class.forName() 可以通过传入一个全限定类名(包含包名)返回一个该类的Class类对象引用 。
  2. Class<?>  classType  =  object.getClass()   通过引用的到Class对象。
  3. Class<?>  classType  =  Object.class  通过类字面常量获得,好处就是懒加载,只有使用时才会加载。

2.获得构造器

  1. 获得指定构造器

    • Constructor<TgetConstructor(Class<?>... parameterTypes)

    • parameterTypes 是 Class[ ] ,它里面的元素和元素顺序与构造器参数对应。

    1. Constructor  constructor  = getConstructor(new Class[ ] { } ),获得默认构造器。
    2. Constructor  constructor  = getConstructor(new Class[ ] {String.class, int.class}),获得参数为(String,int) 的构造器。
  2. 获得所有构造器

    • Constructor[ ]  constructor = classType.getConstructors()

3.获得字段

  1. 获得public字段

    1. Field field =  classTypre.getField( String name ) ;  获得对应名称的字段,注意只能获得所有public字段,包括父类的public字段,其他权限的字段无法获得。
    2. Field[ ] fields =  classTypre.getField() ;  获得所有public字段的数组。
  2. 获得自身字段

    1. Field field = classTypre.getDeclaredField( String name); 获得 当前类定义的字段,包括所有权限。不包括父类任何字段,哪怕是public。
    2. Field[ ] fields =  classTypre.getDeclaredField() ;  获得所有字段的数组。
  3. 获得所有字段包括父类的字段

    1. getSuperClass()获得父类Class对象,getSuperClass()
    2. 循环调用 getSuperClass()和getDeclaredFields[ ],把Field放入List即可。

4.获得方法

  1. 获得public方法

    1. Method method=  classTypre.getMethod ( String name ,Class<?>... parameterTypes) ;  根据方法签名的方法。

      • name是方法名,parameterTypes是 Class [ ],用来获取方法参数的类型
      • 注意只能获得所有public方法,包括父类的public字段,其他权限的字段无法获得。
    2. Method [ ] methods=  classTypre.geMethods() ;  获得所有public方法。
  2. 获得自身方法

    1. Method method= classTypre.getDeclaredMethod (String name ,Class<?>... parameterTypes);

      • 获得 当前类定义的方法,包括所有权限。不包括父类任何方法,哪怕是public。
    2. Method [ ] methods=  classTypre.getDeclaredMethods() ;  获得所有字段的数组。
  3. 获得所有字段包括父类的方法

    1. getSuperClass()获得父类Class对象,getSuperClass()
    2. 循环调用 getSuperClass()和getDeclaredMethods(),把Method放入List即可。

5.获取修改字段相关信息

  • 反射只是通过Class对象获得方法和字段,要获取实例的字段就要传入一个具体的实例。
  1. 获取字段值

    1. Object value = field.get( Object obj)  通过get方法获得实例对象obj对应的field的值。
    2. 如果field是静态字段则可以直接使用get(null)获取值。
    3. 获取基本类型字段的值 : int value = field.get(Object obj) 获取int类型的字段。还有其他类型也是用同样的方法。
    4. private修饰的字段无法直接获得,必须先设置file.setAccessible(true) 才能访问
  2. 获取字段相关信息并通过Modifier解析修饰符

    1. Annotation<?> annotation  = field.getAnnotation(Class<T> annotationClass) 返回字段上的指定注解
    2. Annotation[ ] annotations = field.getDeclaredAnnotations() 返回字段上的所有注解数组
    3. Class<?> type = field.getType()  返回 字段 的类型 的 Class对象。
    4. int  modifier = field.getModifiers()  以int形式返回字段的修饰符。

      • 通过Modifier静态方法判断是不是某一个权限修饰符,如Modifier.isPrivate(modifier)
      • 再如:Modifier.isStatic(modifier) 判断是不是静态成员
      • Modifier静态方法toString 返回权限标识符。
  3. 设置修改字段值

    1. field.set( Object obj, Object value)  通过set方法设置实例对象obj对应的file字段的值为value。
    2. 设置基本类型字段的值 :field.set(Object obj,int value) 获取int类型的字段。还有其他类型也是用同样的方法。
    3. private修饰的字段无法直接设置,必须先设置field.setAccessible(true) 才能设置。
    4. 被final修饰的字段,可以通过反射临时修改值,但是不会把原始值修改了,所以final是绝对不可变的。

6.获取方法相关信息

  • 和字段一样需要传入一个实例对象。
  1. 获取字段相关信息并通过Modifier解析修饰符

    1. Annotation<?> annotation  = method.getAnnotation(Class<T> annotationClass) 返回方法上的指定注解
    2. Annotation[ ] annotations = method.getDeclaredAnnotations() 返回方法上的所有注解数组
    3. Class<?> type = field.getReturnType()  返回 方法返回值类型 的 Class对象。
  2. int  modifier = method.getModifiers()  以int形式返回字段的修饰符。

      • 通过Modifier静态方法判断是不是某一个权限修饰符,如Modifier.isPrivate(modifier)
      • 再如:Modifier.isStatic(modifier) 判断是不是静态成员
      • Modifier静态方法toString 返回权限标识符。
  3. 通过反射调用方法

    1. method.invoke(Object obj, Object... args)  传入实例对象obj和方法对应的参数。
    2. private修饰的方法无法反射,必须先设置method.setAccessible(true) 才能反射调用。

7.创建实例对象其他办法

  1. 通过反射得来的构造器创建实例。
    1. 默认构造器创建对象。

       Constructor<?> constructor = studentClass1.getConstructor(new Class[]{});
      Student student1 = (Student)constructor.newInstance();

      也可以写成constructor.newInstance(new Object[ ]  {  })

    2. 带参构造器创建对象。
       Constructor<?> constructor2 = studentClass1.getConstructor(new Class[]{int.class});
      Student student2 = (Student)constructor2.newInstance(12);

      也可以写成constructor.newInstance(new Object[ ]  { 12 })

  2. 通过Class对象创建实例
    Student student3 = Student.class.newInstance();
  3. 还有通过 new 、 反序列化、colon( ) 方法创建对象,Java中所以一共有5种方法创建实例对象。

JAVA 反射用法的更多相关文章

  1. 不藏了,这些Java反射用法总结都告诉你们

    摘要:Java反射是一种非常强大的机制,它可以在同一个系统中去检测内部的类的字段.方法和构造函数.它非常多的Java框架中,都大量应用了反射技术,如Hibernate和Spring.可以说,反射机制的 ...

  2. Java之反射 — 用法及原理

    Java之反射 - 用法及原理 定义 Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意方法和属性:这种动态获取信息以及动态调用对象 ...

  3. java反射-- Field 用法实践

    java 反射是一种常用的技术手段, 通过加载类的字节码的方式来获取相关类的一些信息 比如成员变量, 成员方法等. Field 是什么呢? field 是一个类, 位于java.lang.reflec ...

  4. java 反射 动态代理

    在上一篇文章中介绍Java注解的时候,多次提到了Java的反射API.与javax.lang.model不同的是,通过反射API可以获取程序在运行时刻的内部结构.反射API中提供的动态代理也是非常强大 ...

  5. java反射机制 + Method.invoke解释 getMethod + 反射理解

    功能: 通过读取另一个Dll去创建一个控件(Form,Button,TextBox,DataGridView),然后对当中一些属性进行检查. 创建控件的大致流程是,Assembly->Modul ...

  6. Java反射机制深度剖析

    版权声明:本文为博主原创文章,转载请注明出处,欢迎交流学习! Java反射机制是Java语言中一种很重要的机制,可能在工作中用到的机会不多,但是在很多框架中都有用到这种机制.我们知道Java是一门静态 ...

  7. Java反射机制剖析(一)-定义和API

    1.     什么是Java反射机制 Java的反射机制是在程序运行时,能够完全知道任何一个类,及其它的属性和方法,并且能够任意调用一个对象的属性和方法.这种运行时的动态获取就是Java的反射机制.其 ...

  8. 如何提高使用Java反射的效率?

    前言 在我们平时的工作或者面试中,都会经常遇到“反射”这个知识点,通过“反射”我们可以动态的获取到对象的信息以及灵活的调用对象方法等,但是在使用的同时又伴随着另一种声音的出现,那就是“反射”很慢,要少 ...

  9. 深入解析Java反射基础

    博客原文:http://www.sczyh30.com/posts/Java/java-reflection-1/ - 这老哥写的特别好 一.回顾:什么是反射? 反射(Reflection)是Java ...

随机推荐

  1. 【题解】Luogu P2047 社交网络总结 (Floyd算法,最短路计数)

    题目描述 在社交网络(social network)的研究中,我们常常使用图论概念去解释一些社会现象.不妨看这样的一个问题.在一个社交圈子里有n个人,人与人之间有不同程度的关系.我 们将这个关系网络对 ...

  2. IntelliJ IDEA(2018)安装详解

    转: IntelliJ IDEA(2018)安装详解 置顶 2018年06月06日 22:58:45 Lazymanx 阅读数:95701   版权声明: https://blog.csdn.net/ ...

  3. java开发爬虫Deno

    java开发爬虫Deno 身为一个程序员不会两三手爬虫怎么能在行业里立足啊,这是开发中自己写的一个java爬虫的Demo,供大家参考. java爬虫的开发依赖于jsoup.jar 直接上代码 publ ...

  4. kubespray 一键安装k8s集群

    1. clone代码 git clone https://github.com/kubernetes-incubator/kubespray.git 2. 添加inventory/inventory ...

  5. k8s pod的4种网络模式最佳实战(externalIPs )

    [k8s]k8s pod的4种网络模式最佳实战(externalIPs )       hostPort相当于docker run -p 8081:8080,不用创建svc,因此端口只在容器运行的vm ...

  6. logstash marking url as dead 问题解决

    具体问题如下图所示: 将 INFO 信息打印大致如下所示: [2018-03-05T16:26:08,711][INFO ][logstash.setting.writabledirectory] C ...

  7. python3中__get__,__getattr__,__getattribute__的区别

    __get__,__getattr__和__getattribute都是访问属性的方法,但不太相同. object.__getattr__(self, name) 当一般位置找不到attribute的 ...

  8. 一个ssm综合小案例-商品订单管理-第二天

    准确来说是第二三天,一时兴起,把这个小项目一鼓作气写完了(较大的bug 均已被我手动捉出并 fix )才来写一篇博客. 接上文 第一天配置继续讲解:

  9. IO 复习字节流字符流拷贝文件

    /* 本地文件 URL 文件拷贝 *//*文本文件拷贝 可以通过 字符流,也可以通过字节流*/ /*二进制文件拷贝 只可以通过字节流*//* 希望这个例子能帮助搞懂 字符流与字节流的区别 */ imp ...

  10. python学习笔记6--操作redis

    一.redis操作 import redis r=redis.Redis(host='211.149.218.16',port=6379,password='123456',db=2) r.set(' ...