- 浏览: 84022 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (110)
- 异常信息 (3)
- JVM (3)
- Maven (2)
- 安全加密 (4)
- server服务类 (8)
- 前端技术类 (7)
- 设计模式 (2)
- memcached (0)
- mongodb (3)
- pinyin4j (1)
- struts2 (1)
- 杂烩 (26)
- 爬虫 (3)
- Java反射 (2)
- RMI (1)
- Velocity (2)
- node.js (0)
- GIT (4)
- ffmpeg与java (1)
- Spring Boot (0)
- Linux (3)
- Spring (4)
- 七牛云服务 (1)
- shell (2)
- python (0)
- JNI实现Java和其他语言的通信 (0)
- nutz (1)
- zookeeper (1)
- dubbo (0)
- Druid数据库连接池 (1)
- redis (14)
- hessian (0)
- RabbitMQ (0)
- ActiveMQ (1)
- JFinal极速 web 开发框架 (0)
- solr (0)
- jersey【RESTful Web Services in Java】 (0)
- GO学习 (6)
- nginx (1)
- TapeStry (2)
- Disruptor,并发 (1)
- Mybatis (1)
最新评论
-
qii404:
推荐另一个Redis可视化客户端,开源并且跨平台支持,性能可以 ...
redis可视化工具RedisClient使用
本人菜鸟,今天恰好有时间,写写博客,总结复习一下java反射方面的知识,欢迎大家探讨交流学习指教
首先看看java中的Class
接着我们来看看获得某个类的信息(成员方法,成员变量,构造函数)
最后我们来看看方法的反射操作
首先看看java中的Class
package demo; public class ClassTest { /*先了解java中的Class*/ public static void main(String[] args) { //任何一个类都是Class的实例对象,这个实例对象有3种表示方式 //01方式 及任何一个类都有一个隐含的静态成员变量class Class c1 = Foo.class; //02方式 已知该类的对象通过getClass方法 Foo foo = new Foo(); Class c2 = foo.getClass(); /*c1、c2表示了Foo的类类型(class type)*/ System.out.println(c1==c2);//控制台将显示true 说明:c1 ,c2 都表示了Foo类的类类型 //03方式 Class c3 = null; try { c3 = Class.forName("demo.Foo");//动态加载 } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(c2==c3);//控制台将显示true 说明:c2 ,c3s 都表示了Foo类的类类型 //接下来我们通过c1,c2,c3的方式创建Foo的实例 try { Foo f = (Foo)c1.newInstance(); f.say();//运行将打印 哈哈哈 } catch (InstantiationException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IllegalAccessException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } class Foo{ void say(){ System.out.println("哈哈哈"); } }
接着我们来看看获得某个类的信息(成员方法,成员变量,构造函数)
package demo; import java.lang.reflect.Constructor; import java.lang.reflect.Field; import java.lang.reflect.Method; public class GetInformationOfClassUtil { /** *获得某个类的信息(成员方法,成员变量,构造函数) * @param obj * */ public static void getInformation(Object obj){ //第一步, 获得类的类型 Class c = obj.getClass();//传递的是哪个子类的对象,c就是哪个子类的类类型 //第二步, 获得类的名称 String className = c.getName(); System.out.println(className+"类的所有方法"); //第三步, 获得方法名称及返回值及参数 /*此处说明:注意Method类,可称作方法对象 * c.getMethods() 获得的是所有public的方法,包括从父类继承而来的方法 * c.getDeclaredAnnotations() 获得的是所有该类自己声明的全部访问权限的方法 * */ Method[] methods = c.getMethods(); for (Method method : methods) { Class returnType = method.getReturnType();//方法的返回值类类型 String returnClassName = returnType.getName();//方法的返回值类类型的名称 String methodName = method.getName();//方法名称 System.out.print(returnClassName+" "+methodName+"("); Class[] parameterTypes = method.getParameterTypes();//获得参数列表的类类型 for (Class class1 : parameterTypes) { System.out.print(class1.getName()+",");//每个参数的类类型的名称 } System.out.println(")"); } System.out.println("所有的成员变量"); //第四步, 获得成员变量 /*注:成员变量也是对象(java.lang.reflect.Field) * c.getFields() 获得的是所有public的成员变量的信息 * c.getDeclaredFields() 获得是是该类自己所有的成员变量的信息 * */ Field[] fields = c.getDeclaredFields(); for (Field field : fields) { Class fieldType = field.getClass();//得到成员变量的类类型 String fieldTypeName = fieldType.getName();//得到成员变量的类类型名称 System.out.println(field.getName()); } System.out.println("所有的构造函数"); /*构造函数或者称呼为构造方法也是对象(java.lang.Constructor) * c.getConstructors() 获得所有public的构造函数 * c.getDeclaredConstructors(); 获得的是所有的构造函数 * */ Constructor[] Constructors = c.getConstructors(); for (Constructor constructor : Constructors) { String constructorName = constructor.getName(); System.out.print(constructorName+"("); //构造函数的参数列表 Class[] parmTypes = constructor.getParameterTypes(); for (Class class1 : parmTypes) { String parmTypeName = class1.getName(); System.out.print(parmTypeName+","); } System.out.println(")"); } } //接下来我们来测试获得String类的信息 public static void main(String[] args) { String s = ""; GetInformationOfClassUtil.getInformation(s); //测试结果如下 /*java.lang.String类的所有方法 * int hashCode() int compareTo(java.lang.Object,) int compareTo(java.lang.String,) int indexOf(java.lang.String,int,) int indexOf(java.lang.String,) int indexOf(int,) int indexOf(int,int,) boolean equals(java.lang.Object,) java.lang.String toString() char charAt(int,) int codePointAt(int,) int codePointBefore(int,) int codePointCount(int,int,) int compareToIgnoreCase(java.lang.String,) java.lang.String concat(java.lang.String,) boolean contains(java.lang.CharSequence,) boolean contentEquals(java.lang.StringBuffer,) boolean contentEquals(java.lang.CharSequence,) java.lang.String copyValueOf([C,int,int,) java.lang.String copyValueOf([C,) boolean endsWith(java.lang.String,) boolean equalsIgnoreCase(java.lang.String,) java.lang.String format(java.lang.String,[Ljava.lang.Object;,) java.lang.String format(java.util.Locale,java.lang.String,[Ljava.lang.Object;,) [B getBytes(java.nio.charset.Charset,) [B getBytes() [B getBytes(java.lang.String,) void getBytes(int,int,[B,int,) void getChars(int,int,[C,int,) java.lang.String intern() boolean isEmpty() int lastIndexOf(java.lang.String,) int lastIndexOf(int,) int lastIndexOf(int,int,) int lastIndexOf(java.lang.String,int,) int length() boolean matches(java.lang.String,) int offsetByCodePoints(int,int,) boolean regionMatches(int,java.lang.String,int,int,) boolean regionMatches(boolean,int,java.lang.String,int,int,) java.lang.String replace(char,char,) java.lang.String replace(java.lang.CharSequence,java.lang.CharSequence,) java.lang.String replaceAll(java.lang.String,java.lang.String,) java.lang.String replaceFirst(java.lang.String,java.lang.String,) [Ljava.lang.String; split(java.lang.String,int,) [Ljava.lang.String; split(java.lang.String,) boolean startsWith(java.lang.String,int,) boolean startsWith(java.lang.String,) java.lang.CharSequence subSequence(int,int,) java.lang.String substring(int,) java.lang.String substring(int,int,) [C toCharArray() java.lang.String toLowerCase() java.lang.String toLowerCase(java.util.Locale,) java.lang.String toUpperCase() java.lang.String toUpperCase(java.util.Locale,) java.lang.String trim() java.lang.String valueOf([C,) java.lang.String valueOf(int,) java.lang.String valueOf(long,) java.lang.String valueOf(float,) java.lang.String valueOf(double,) java.lang.String valueOf(java.lang.Object,) java.lang.String valueOf(char,) java.lang.String valueOf([C,int,int,) java.lang.String valueOf(boolean,) void wait() void wait(long,int,) void wait(long,) java.lang.Class getClass() void notify() void notifyAll() 所有的成员变量 value offset count hash serialVersionUID serialPersistentFields CASE_INSENSITIVE_ORDER 所有的构造函数 java.lang.String() java.lang.String(java.lang.String,) java.lang.String([C,) java.lang.String([C,int,int,) java.lang.String([I,int,int,) java.lang.String([B,int,int,int,) java.lang.String([B,int,) java.lang.String(java.lang.StringBuilder,) java.lang.String([B,int,int,java.lang.String,) java.lang.String([B,int,int,java.nio.charset.Charset,) java.lang.String([B,java.lang.String,) java.lang.String([B,java.nio.charset.Charset,) java.lang.String([B,int,int,) java.lang.String([B,) java.lang.String(java.lang.StringBuffer,) * * */ } }
最后我们来看看方法的反射操作
package demo; import java.lang.reflect.Method; public class refectOfMethod { public static void main(String[] args) { /* * 方法的反射操作 如何获得某一个方法(注:方法的名称和参数列表决定了方法和其他方法的区别) * 例如:获取work(int,int)方法;分析:要获得一个方法也就是必须先要获得该类得信息,也就是要先获得该类的类类型 */ Auto auto = new Auto(); Class c = auto.getClass(); /* 接下来,根据方法名称,参数列表来决定获取的方法 注:c.getMethod(name, parameterTypes); 获得的是所有public的方法,包括从父类继承而来的方法 c.getDeclaredMethod(name, parameterTypes); 获得的是所有该类自己声明的全部访问权限的方法 */ //调用方法01 try { Method method = c.getMethod("work",new Class[]{int.class,int.class}); //或者Method method = c.getMethod("work",int.class,int.class); //方法的反射,及用method对象来进行方法的调用了,而不是使用auto.work()这种方式调用了 method.invoke(auto,2,4);//此处等同于method.invoke(auto,new Object[]{2,4});或者auto.work(2,4); } catch (Exception e) { e.printStackTrace(); } //调用方法02 try { Method method2 = c.getMethod("work",new Class[]{String.class,String.class}); //或者Method method = c.getMethod("work",int.class,int.class); //方法的反射,及用method对象来进行方法的调用了,而不是使用auto.work()这种方式调用了 method2.invoke(auto,"hello","word");//此处等同于method.invoke(auto,new Object[]{"hello","word");或者auto.work("hello","word"); } catch (Exception e) { e.printStackTrace(); } //调用方法03 try { Method method2 = c.getMethod("work"); //或者Method method = c.getMethod("work",int.class,int.class); //方法的反射,及用method对象来进行方法的调用了,而不是使用auto.work()这种方式调用了 method2.invoke(auto);//此处等同于method.invoke(auto);或者auto.work(); } catch (Exception e) { e.printStackTrace(); } } } class Auto{ //方法01 public void work(int a,int b){System.out.println(a+b);} //方法02 public String work(String a,String b){ System.out.println(a+b); return a+b;} //方法03 public void work(){System.out.println("哈哈");} }
相关推荐
Java反射是Java编程语言中的一个重要特性,它允许程序在运行时动态地获取类的信息并操作类的对象。在Java中,反射机制提供了强大的能力,包括在运行时检查类的结构、创建对象实例、调用方法以及访问和修改字段值。...
Java反射机制是Java编程语言中的一个强大特性,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。这个特性使得Java具有了高度的灵活性和动态性,尤其是在处理元数据、创建对象、调用私有方法...
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射主要用于在运行时分析类和对象,包括访问私有成员、调用私有方法、创建对象、获取类...
Java反射机制是Java语言提供的一种强大功能,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射机制的核心类是java.lang.Class,它代表了运行时的类信息。通过Class对象,我们...
在本文中,我们将深入探讨如何使用Java反射来获取并执行某个特定的方法。 首先,我们需要了解Java反射的基本概念。`java.lang.Class`类是反射的核心,它代表了Java中的每一个类。我们可以通过以下方式获取到一个...
### Java反射性能测试分析 #### 引言 Java反射机制是Java编程语言中一个强大的特性,它允许程序在运行时动态地访问、检测和修改类、接口、字段和方法等对象。然而,反射操作通常会引入额外的开销,这在性能敏感的...
### Java反射机制总结 #### 反射的概念与起源 反射的概念最早由Smith于1982年提出,指的是程序能够访问、检测并修改其自身状态或行为的能力。这一概念的提出迅速引起了计算机科学领域的广泛关注,并在之后的研究中...
Java反射是Java编程语言中的一个强大特性,它允许运行时的程序访问并操作类、接口、字段和方法等信息,即使这些信息在编译时并未明确知晓。在Java中,反射通常通过`java.lang.Class`类和相关的API来实现。本实例将...
### 反射实例—JAVA反射机制 #### 一、反射概念及原理 反射在计算机科学领域,特别是程序设计中,是指程序有能力访问、检测和修改其自身的结构和行为。这一概念最早由Smith于1982年提出,并迅速应用于各种编程语言...
### Java反射机制详解 #### 一、什么是Java反射? Java反射是Java编程语言的一个特性,它允许运行时检查和操作程序结构(类、字段、方法等)。反射的主要用途包括但不限于:动态实例化对象、访问私有成员、调用...
Java反射是Java语言提供的一种强大的动态类型特性,它允许程序在运行时检查类、接口、字段和方法的信息,并且能够动态地创建对象和调用方法。这个能力使得开发者可以突破静态类型的束缚,实现一些在编译时期无法完成...
Java反射是Java编程语言中的一个强大特性,它允许在运行时检查类、接口、字段和方法的信息,并且能够在运行时动态地创建对象和调用方法。这个特性使得Java具有高度的灵活性,尤其在处理框架、插件系统以及元数据驱动...
### Java反射机制详解 #### 一、反射的基本概念与历史背景 反射的概念最早由Smith在1982年提出,其核心思想是程序有能力访问、检测甚至修改自身的状态和行为。这种能力一经提出,迅速成为了计算机科学领域的研究...
### Java反射机制与NoSuchMethodException详解 在Java编程中,反射是一种强大的机制,允许程序在运行时检查和修改自身结构和行为。然而,当开发者尝试使用反射调用一个不存在的方法时,便会遇到`java.lang....
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在Java中,反射主要用于在运行时分析类和对象,包括访问私有成员、调用私有方法、创建动态代理等。...
Java反射是Java编程语言中的一个强大工具,它允许运行中的Java程序对自身进行检查并且可以直接操作程序的内部属性。在给定的“利用java反射将json字符串转成对象”的主题中,我们将深入探讨如何借助反射机制将JSON...
### Java反射机制详解 #### 一、什么是Java反射机制? Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的...
Java反射机制是Java编程语言中的一个强大工具,它允许程序在运行时检查并操作类、接口、字段和方法等对象。在"北大青鸟java反射机制"的学习资料中,我们将会深入探讨这一核心特性。 首先,我们要理解反射的核心概念...
### Java反射机制详解 #### 一、引言 在Java编程语言中,反射(Reflection)是一种强大的工具,它允许程序在运行时访问类的信息,并能够动态地创建对象、调用方法以及获取字段值等。这种能力对于框架设计、代码...