你需要理解的Java反射机制知识总结

反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制。【翻译于 官方文档】

本篇将从以下几个方面讲述反射的知识:

  • class 的使用
  • 方法的反射
  • 构造函数的反射
  • 成员变量的反射

一、什么是class类

在面向对象的世界里,万物皆对象。类是对象,类是java.lang.Class类的实例对象。另外class类只有java虚拟机才能new出来。任何一个类都是Class 类的实例对象。这实例对象有三种表达方式:


  1. public class User{ 
  2.  
  3. public class ClassTest{ 
  4. User u=new User(); 
  5. //方式1: 
  6. Class c1=User.class; 
  7. //方式2: 
  8. Class c2=u.getClass(); 
  9. //方式3: 
  10. Class c3=Class.forName("com.forezp.User"); //可以通过类的类型创建该类的实例对象 User user=(User)c1.newInstance(); 

二、class类的动态加载

Class.forName(类的全称);该方法不仅表示了类的类型,还代表了动态加载类。编译时刻加载类是静态加载、运行时刻加载类是动态加载类。

三、获取方法信息

基本的数据类型,void关键字都Class 类的实例;可以通过getame();getSimpleName()获取类的名称。


  1. Class c1=String.class; 
  2. Class c2=int.class; 
  3. Class c3=void.class; 
  4. System.out.println(c1.getName()); 
  5. System.out.println(c2.getSimpleName()); 

获取类的所有方法,并打印出来:


  1. public static void printClassInfo(Object object){ 
  2.         Class c=object.getClass(); 
  3.         System.out.println("类的名称:"+c.getName()); 
  4.  
  5.         /** 
  6.          * 一个成员方法就是一个method对象 
  7.          * getMethod()所有的 public方法,包括父类继承的 public 
  8.          * getDeclaredMethods()获取该类所有的方法,包括private ,但不包括继承的方法。 
  9.          */ 
  10.         Method[] methods=c.getMethods();//获取方法 
  11.         //获取所以的方法,包括private ,c.getDeclaredMethods(); 
  12.  
  13.         for(int i=0;i<methods.length;i++){ 
  14.             //得到方法的返回类型 
  15.             Class returnType=methods[i].getReturnType(); 
  16.             System.out.print(returnType.getName()); 
  17.             //得到方法名: 
  18.             System.out.print(methods[i].getName()+"("); 
  19.  
  20.             Class[] parameterTypes=methods[i].getParameterTypes(); 
  21.             for(Class class1:parameterTypes){ 
  22.                 System.out.print(class1.getName()+","); 
  23.             } 
  24.             System.out.println(")"); 
  25.         } 
  26.     }

  1. public class ReflectTest { 
  2.  
  3.         public static void main(String[] args){ 
  4.                 String s="ss"; 
  5.                 ClassUtil.printClassInfo(s); 
  6.         } 

运行:


  1. 类的名称:java.lang.String 
  2.  
  3. booleanequals(java.lang.Object,) 
  4.  
  5. java.lang.StringtoString() 
  6.  
  7. inthashCode() 
  8.  
  9. … 

四、获取成员变量的信息

也可以获取类的成员变量信息


  1. public static void printFiledInfo(Object o){ 
  2.  
  3.         Class c=o.getClass(); 
  4.         /** 
  5.          * getFileds()获取public 
  6.          * getDeclaredFields()获取所有 
  7.          */ 
  8.         Field[] fileds=c.getDeclaredFields(); 
  9.  
  10.         for(Field f:fileds){ 
  11.             //获取成员变量的类型 
  12.             Class filedType=f.getType(); 
  13.             System.out.println(filedType.getName()+" "+f.getName()); 
  14.         } 
  15.  
  16.     }

  1. public static void main(String[] args){ 
  2.                 String s="ss"; 
  3.                 //ClassUtil.printClassInfo(s); 
  4.                 ClassUtil.printFiledInfo(s); 
  5.         } 

运行:


  1. [C value 
  2. int hash 
  3. long serialVersionUID 
  4. [Ljava.io.ObjectStreamField; serialPersistentFields 
  5. java.util.Comparator CASE_INSENSITIVE_ORDER 
  6. int HASHING_SEED 
  7. int hash32 

五、获取构造函数的信息


  1. public static void printConstructInfo(Object o){ 
  2.         Class c=o.getClass(); 
  3.  
  4.         Constructor[] constructors=c.getDeclaredConstructors(); 
  5.         for (Constructor con:constructors){ 
  6.             System.out.print(con.getName()+”(“); 
  7.  
  8.             Class[] typeParas=con.getParameterTypes(); 
  9.             for (Class class1:typeParas){ 
  10.                 System.out.print(class1.getName()+” ,”); 
  11.             } 
  12.             System.out.println(“)”); 
  13.         } 
  14.     }

  1. public static void main(String[] args){ 
  2.                String s="ss"; 
  3.                //ClassUtil.printClassInfo(s); 
  4.                //ClassUtil.printFiledInfo(s); 
  5.                ClassUtil.printConstructInfo(s); 
  6.        } 

运行:


  1. java.lang.String([B ,) 
  2. java.lang.String([B ,int ,int ,) 
  3. java.lang.String([B ,java.nio.charset.Charset ,) 
  4. java.lang.String([B ,java.lang.String ,) 
  5. java.lang.String([B ,int ,int ,java.nio.charset.Charset ,) 
  6. java.lang.String(int ,int ,[C ,) 
  7. java.lang.String([C ,boolean ,) 
  8. java.lang.String(java.lang.StringBuilder ,) 
  9. java.lang.String(java.lang.StringBuffer ,) 
  10.  
  11. ...  

六、方法反射的操作

获取一个方法:需要获取方法的名称和方法的参数才能决定一个方法。

方法的反射操作:


  1. method.invoke(对象,参数列表); 

举个例子:


  1. class A{ 
  2.  
  3.     public void add(int a,int b){ 
  4.         System.out.print(a+b); 
  5.     } 
  6.  
  7.     public void toUpper(String a){ 
  8.         System.out.print(a.toUpperCase()); 
  9.     } 
  10. }

  1. public static void main(String[] args) { 
  2.         A a=new A(); 
  3.         Class c=a.getClass(); 
  4.         try { 
  5.             Method method=c.getMethod("add",new Class[]{int.class,int.class}); 
  6.             //也可以 Method method=c.getMethod("add",int.class,int.class); 
  7.             //方法的反射操作 
  8.             method.invoke(a,10,10); 
  9.         }catch (Exception e){ 
  10.             e.printStackTrace(); 
  11.         } 
  12.     } 

运行:

20

本篇文章已经讲解了java反射的基本用法, 它可以在运行时判断任意一个对象所属的类;在运行时构造任意一个类的对象;在运行时判断任意一个类所具有的成员变量和方法;在运行时调用任意一个对象的方法;生成动态代理。

作者:方志朋

来源:51CTO

时间: 2024-09-14 03:21:52

你需要理解的Java反射机制知识总结的相关文章

Java反射机制:包括组成、结构和示例说明等内容

第1部分 Java 反射机制介绍 Java 反射机制.通俗来讲呢,就是在运行状态中,我们可以根据"类的部分已经的信息"来还原"类的全部的信息".这里"类的部分已经的信息",可以是"类名"或"类的对象"等信息."类的全部信息"就是指"类的属性,方法,继承关系和Annotation注解"等内容. 举个简单的例子:假设对于类ReflectionTest.java,我们知道的

Java 反射机制详解及实例代码_java

Java反射详解 本篇文章依旧采用小例子来说明,因为我始终觉的,案例驱动是最好的,要不然只看理论的话,看了也不懂,不过建议大家在看完文章之后,在回过头去看看理论,会有更好的理解. 下面开始正文. [案例1]通过一个对象获得完整的包名和类名 package Reflect; /** * 通过一个对象获得完整的包名和类名 * */ class Demo{ //other codes... } class hello{ public static void main(String[] args) {

java反射机制剖析(一)—简介

    由之前动态代理的学习再次接触到反射这个知识点,第二次接触了所以做了一些稍微深入的了解.那么,对于反射这部分的内容我打算分三篇博客来总结.本篇博客先对反射做一个大概的了解,包括反射有关的RTTI.定义的理解以及涉及到的其他知识的简介. 回顾     java之前我接触反射这个知识,是在大话设计中的抽象工厂模式里,通过反射+配置文件来优化抽象工厂提高其应对需求变更的灵活性.当时对于反射的认知仅仅是它是一种技术,一种实例化对象的技术,一种实例化对象不依赖于写死的代码的技术.简单的说就是,它是一

Java反射机制的学习

Java反射机制是Java语言被视为准动态语言的关键性质.Java反射机制的核心就是允许在运行时通过Java Reflection APIs来取得已知名字的class类的相关信息,动态地生成此类,并调用其方法或修改其域(甚至是本身声明为private的域或方法). 也许你使用Java已经很长时间了,可是几乎不会用到Java反射机制.你会嗤之以鼻地告诉我,Java反射机制没啥用.或许在J2EE.J2SE等平台,Java反射机制没啥用(具体我也不了解,不多做评论),但是在Android应用开发中,该

java 反射机制系列(一) 初识Java Reflection

Java 反射机制是指Java程序可以在执行期载入,探知,使用编译期间完全未知的classes.这句话可能有点难以理解,我们可以通过一个例子来看.在Java程序中我们经常会用到这样一条语句来创建一个对象.Date date = new Date();在这条语句中date的类型(Java.util.Date)在编译时 已经确定.那么,有没有办法使我们把对象类型的确定时间由编译转到运行,答案是肯定的.这就是Java反射机制所提供的便利.而且它不单单可以生成对象还可以获取Field,对Field设值,

java 利用java反射机制动态加载类的简单实现_java

如下所示: ////////////////// Load.java package org.bromon.reflect; import java.util.ArrayList; import java.util.List; public class Load implements Operator { @Override public List<?> act(List<?> params) { // TODO Auto-generated method stub List<

Java反射机制应用实践

引言 Java反射机制是一个非常强大的功能,在很多大型项目比如Spring, Mybatis都可以看见反射的身影.通过反射机制我们可以在运行期间获取对象的类型信息,利用这一特性我们可以实现工厂模式和代理模式等设计模式,同时也可以解决Java泛型擦除等令人苦恼的问题.本文我们就从实际应用的角度出发,来应用一下Java的反射机制. 反射基础 p.s: 本文需要读者对反射机制的API有一定程度的了解,如果之前没有接触过的话,建议先看一下官方文档的Quick Start. 在应用反射机制之前,首先我们先

一个例子让你了解Java反射机制

通俗地说,反射机制就是可以把一个类,类的成员(函数,属性),当成一个对象来操作,希望读者能理解,也就是说,类,类的成员,我们在运行的时候还可以动态地去操作他们. 理论的东东太多也没用,下面我们看看实践 Demo - Demo: package cn.lee.demo; import java.lang.reflect.Constructor; import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetExce

Java反射机制剖析:定义和API

1.什么是Java反射机制 Java的反射机制是在程序运行时,能够完全知道任何一个类,及其它的属性和方法,并且能够任意调用一个对象的属性和方法.这种运行时的动态获取就是Java的反射机制.其实这也是Java是动态语言的一个象征. 用一句话来概括反射就是加载一个运行时才知道的类以及它的完整内部结构. 2.为什么要有Java反射机制 我们为什么要用Java的反射机制呢? 我认为有两种: 第一种:反射的目的就是为了扩展未知的应用.比如你写了一个程序,这个程序定义了一些接口,只要实现了这些接口的dll都