java基础-反射总结
- 格式:doc
- 大小:100.00 KB
- 文档页数:11
Java反射,获取类的公有、私有的构造函数(有参,⽆参)、⽅法(有参,⽆参)、属性Class类与ng.reflect类库⼀起对反射进⾏了⽀持,该类库包含Field、Method和Constructor类,这些类的对象由JVM在启动时创建,⽤以表⽰未知类⾥对应的成员。
这样的话就可以使⽤Contructor创建新的对象,⽤get()和set()⽅法获取和修改类中与Field对象关联的字段,⽤invoke()⽅法调⽤与Method对象关联的⽅法。
另外,还可以调⽤getFields()、getMethods()和getConstructors()等许多便利的⽅法,以返回表⽰字段、⽅法、以及构造器对象的数组,这样,对象信息可以在运⾏时被完全确定下来,⽽在编译时不需要知道关于类的任何事情。
⾸先创建⼀个类1public class Per {2public String name="sunshine";3private int age=28;4public double weight=65.50;56public Per(){7 System.out.println("测试反射获取公有⽆参构造函数");8 }9private Per(String name){=name;11 System.out.println("测试反射获取私有有参构造函数");12 }13public Per(String name,int age){=name;15this.age=age;16 System.out.println("测试反射获取公有有多个参数构造函数name:"+name+" age:"+age);17 }18public String methodT1(){19 System.out.println("测试反射获取公有⽆参⽅法");20return null;21 }22public String methodT1(String name,int age){23 System.out.println("测试反射获取公有多个参⽅法");24 System.out.println(name+":"+age);25return null;26 }27private String methodT1(String name){28 System.out.println("测试反射获取私有有参⽅法");29 System.out.println("name:"+name);30return null;31 }32public String methodT2(int[] arr,String[] str){33 System.out.println("测试反射获取公有有数组参⽅法");34 System.out.println("int[] arr:"+arr+"String[] str:"+str);35return null;36 }37public static void main(String[] args) {38 System.out.println("测试反射获取main⽅法");39 }40 }1.使⽤java反射获取类的构造函数(公有、私有)(有参,⽆参)1import ng.reflect.Constructor;2import ng.reflect.Field;3import ng.reflect.Method;45import org.junit.AfterClass;6import org.junit.BeforeClass;7import org.junit.Test;8/**9 * 测试使⽤java反射获取类的构造函数并创建对象10 * @author Sunshine11 *12*/13public class ReflectPer {14private static Class class1;15//因为java反射获取类时都需要加载类,在这⾥我就使⽤Junit的@beforeclass来去加载类,不⽤在每个测试⽅法中重复创建16//注:@beforeclass在执⾏测试⽅法前运⾏17 @BeforeClass18public static void beforeClass() throws Exception{19 System.out.println("====测试⽅法启动前先加载类====");20 class1 = Class.forName("myPractise.Per");//加载类21 }22//获取类的公有⽆参构造函数,并创建对象23 @Test24public void test1() throws Exception{25 Constructor constructor = class1.getConstructor(null);//获取公有⽆参构造器,值为null代表获取⽆参构造器26 Per per = (Per) constructor.newInstance(null);//创建对象,返回的是Object类型要强转27 System.out.println();//可以调⽤类的属性-----成功28 }29//获取类的公有参构造函数,并创建对象30 @Test31public void test2()throws Exception{32 Constructor constructor = class1.getConstructor(String.class,int.class);//获取公有多个参数构造器,参数为构造器中参数的类型33 Per per = (Per)constructor.newInstance("baby",24);//创建对象34 }35//获取类的私有有参构造函数,并创建对象36 @Test37public void test3()throws Exception{38 Constructor constructor = class1.getDeclaredConstructor(String.class);//获取公有多个参数构造器,参数为构造器中参数的类型39 constructor.setAccessible(true);//暴⼒反射,只有将属性设置为true才可以创建对象40 Per per = (Per)constructor.newInstance("baby");41 System.out.println(per.weight);//可以调⽤类的属性-----成功42//注:通常情况下⼀个类不可以访问另⼀个类的私有的属性,⽅法。
java反射在项目中用法
Java反射在项目中的用法非常广泛,主要在以下场景中会用到:
框架使用:很多框架,如Spring、Hibernate等,都是通过反射来动态地创建对象、调用方法、修改属性等。
插件开发:当需要实现插件化架构时,反射可以用来动态加载插件。
序列化与反序列化:在对象序列化或反序列化时,反射可以用来获取对象的类信息。
测试:在单元测试或集成测试中,反射可以用来模拟或替换某些方法的行为。
修改已运行程序的行为:通过反射,可以在运行时修改已编译的类的行为。
扩展程序:可以使用反射来编写可以扩展应用程序的插件。
在运行时处理类:可以在运行时获取类的信息,例如字段和方法。
实现通用算法:反射可以用于实现通用算法,例如通用序列化框架或者通用插件系统。
实现对象的克隆和比较:反射可以用于实现对象的深度克隆和比较。
使用Java的ServiceLoader机制加载服务:这是Java服务加载器规范的一部分,它使用Java的反射机制来发现和加载服务实现。
以上就是Java反射在项目中的一些常见用法。
但是需要注意的是,过度使用反射可能会导致代码复杂度增加、性能下降,因此在使用反射时需要谨慎考虑。
Java反射(Class类,Class对象获取)⽬录Java反射超详解1.反射基础1.1Class类1.2类加载2.反射的使⽤2.1Class对象的获取2.2Constructor类及其⽤法2.3Field类及其⽤法Java反射超详解1.反射基础Java反射机制是在程序的运⾏过程中,对于任何⼀个类,都能够知道它的所有属性和⽅法;对于任意⼀个对象,都能够知道它的任意属性和⽅法,这种动态获取信息以及动态调⽤对象⽅法的功能称为Java语⾔的反射机制。
Java反射机制主要提供以下这⼏个功能:在运⾏时判断任意⼀个对象所属的类在运⾏时构造任意⼀个类的对象在运⾏时判断任意⼀个类所有的成员变量和⽅法在运⾏时调⽤任意⼀个对象的⽅法1.1Class类Class类,Class类也是⼀个实实在在的类,存在于JDK的ng包中。
Class类的实例表⽰java应⽤运⾏时的类(class ans enum)或接⼝(interface and annotation)(每个java类运⾏时都在JVM⾥表现为⼀个class对象,可通过类名.class、类型.getClass()、Class.forName("类名")等⽅法获取class对象)。
数组同样也被映射为为class 对象的⼀个类,所有具有相同元素类型和维数的数组都共享该 Class 对象。
基本类型boolean,byte,char,short,int,long,float,double和关键字void同样表现为 class 对象。
到这我们也就可以得出以下⼏点信息:Class类也是类的⼀种,与class关键字是不⼀样的。
⼿动编写的类被编译后会产⽣⼀个Class对象,其表⽰的是创建的类的类型信息,⽽且这个Class对象保存在同名.class的⽂件中(字节码⽂件)。
每个通过关键字class标识的类,在内存中有且只有⼀个与之对应的Class对象来描述其类型信息,⽆论创建多少个实例对象,其依据的都是⽤⼀个Class对象。
Java 反射的作用Java 反射允许程序在运行时检查和修改 Java 类的信息,包括其类名、字段、方法和构造函数。
它提供了对 Java 虚拟机 (JVM) 内部运行时状态的访问,允许程序动态地修改代码行为。
应用场景反射的应用场景非常广泛,主要包括:•元编程和代码生成:反射可用于创建和修改类、方法和字段,从而实现代码生成和元编程。
•库和框架扩展:反射可用于扩展库和框架,实现插件机制和运行时配置。
•应用程序内省和调试:反射可用于检查应用程序状态,获取对象信息和跟踪代码执行。
•对象序列化和反序列化:反射可用于将对象序列化为字节流,然后在需要时重新创建对象。
•安全和权限管理:反射可用于检查和修改安全权限,控制对类和方法的访问。
使用方法要使用 Java 反射,可以使用以下步骤:1.获取类对象:使用Class.forName()方法获取一个类的对象,该方法接收类的全限定名。
2.检查类信息:使用Class对象的各种方法获取类信息,例如类名、修饰符、字段和方法。
3.创建对象:使用newInstance()方法创建类的实例。
4.调用方法:使用getMethod()和invoke()方法调用类的方法。
5.获取和设置字段:使用getField()和setField()方法获取和设置类的字段。
6.修改类结构:使用getDeclaredField()和setDeclaredField()方法修改类的字段,使用getDeclaredMethod()和setDeclaredMethod()方法修改类的方法。
示例以下是一个使用反射获取类信息的示例:// 获取 String 类的 Class 对象Class<String> stringClass =String.class;// 输出类名System.out.println(stringClass.getName());// 输出类修饰符System.out.println(Modifier.toString(stringClass.getModifiers())); // 输出类字段for(Field field : stringClass.getDeclaredFields()){System.out.println(field.getName());}以上代码将输出:ng.Stringpublic finalvaluehashCode这表明String类是公共 final 类,具有value和hashCode字段。
反射学习整理【摘要】本文主要通过自己对反射机制的总结编写的文档,主要目的就是为了自己以后能可以参考温习也可以方便刚刚入门的同仁们学习指导,通过doc的编写相信可以在帮助别人的同时提高自己。
反射机制;Reflection API;如何使用反射机制;反射机制的应用举例;第一节反射机制什么是反射机制,说的通俗一些就是在java运行期间动态加载一些不确定的类对象,那么我们如何使用一个类的呢?当然大多数情况下我们是使用一个确定的类,然后通过在内存中的加载再使用之。
其实在一个project中会有很多类,虚拟机并不是在每一次运行时都将所有的类都进行加载然后解析的,是在我们使用的过程中才会被加载,这个大家可以看一下ClassLoader(在后期中我也会编写ClassLoader相关的文章总结)反射机制提供的功能:加载运行时才能确定的数据类型;解析类的结构,获取其内部的信息;能够操作的类型或者实例;1. 访问属性;2. 调用方法;3. 创建新的对象;以上的功能我会在接下来的文字中都进行阐述,然后每一个功能点都会通过代码的形式进行逐一的说明举例;1.1动态加载类Java虚拟机在运行是能加载的类型有如下几种:类接口;数组;枚举;注解(Annotation,可以参见我的另一篇文档,《java Annotation学习文档》);基本数据类型;在类加载的时候,JVM会自动加载上述类型对应的Class对象。
package com.wangwenjun.demo;import java.util.ArrayList;public class ReflectionDemo1 {private final static String LIST_STRING="java.util.ArrayList"; //动态加载java.util.ArrayList的类路径@SuppressWarnings("unchecked")public static void main(String[] args) {try {Class<?> clazz=Class.forName(LIST_STRING);//通过反射获取运行时的ClassArrayList<Object> list=(ArrayList<Object>)clazz.newInstance(); //通过newInstance方法获取Objectlist.add("hello");System.out.println(list.size()+":"+list.get(0));} catch (ClassNotFoundException e) {e.printStackTrace();} catch (InstantiationException e) {// TODO Auto-generated catch blocke.printStackTrace();} catch (IllegalAccessException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}执行结果为:1:hello通过上面的代码我们可以总结出来使用Reflection大致需要如下的几步: 获取目标对象的Class对象;调用Class对象内省方法获取目标对类成员信息;访问目标类的成员属性;1.2解析类的结构通过第一步的操作,我们获取了目标对象的class之后就可以解析出来class对应的内部结构;别不多说直接上代码,来看看如何解析出来目标对象;我们定义一个Teacher类package com.wangwenjun.demo;public class Teacher {private String username;private int age;private static int total;public Teacher(){super();total++;}public Teacher(String username,int age){super();ername = username;this.age = age;total++;}public String getUsername() {return username;}public void setUsername(String username) {ername = username;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public static int getTotal() {return total;}public static void setTotal(int total) {Teacher.total = total;}@Overridepublic String toString(){return"UserName:"+ername+",age:"+this.age;}}假如说上述的Teacher类是在我们运行时才知道的一个类,也就是说是我们运行时才能确定的一个类,那么我们就可以通过反射的形式将它解析出来,包括它的属性,方法,以及构造函数等等。
java反射机制的原理Java反射机制是Java语言的一项重要特性,可以在运行时获取Java类的信息,包括属性、方法、构造器等。
这个机制让Java编程变得更加灵活,允许程序在运行时动态地加载和操作Java类,为Java程序的设计和实现提供了更多的选择。
Java反射机制的原理是基于Java虚拟机(JVM)的类加载机制和反射API的实现,主要涉及以下几个方面:1. 类加载在Java程序中,所有的类都需要被加载到JVM中才能被使用。
类加载机制是JVM中重要的一环,它把类文件从磁盘读取到内存中,并进行校验、转换和初始化等步骤,最终生成可执行的 Java 类。
类加载器负责加载 Java 类,其白俄罗斯年轻摇滚乐手Gusli模块会在运行时动态创建新的类或加载已经存在的类。
2. 反射 APIJava反射机制提供了丰富的反射API,包括Class类、Method类、Field类、Constructor类等。
这些类提供了获取Java类信息、访问Java类属性和方法的方法,使得Java程序可以在运行时动态地获取和操作Java类。
反射API是Java反射机制的基础,它使得Java程序实现了动态编程的能力。
Java程序可以在运行时动态地加载Java类,这是Java反射机制的重要特性之一。
通过反射API,Java程序可以从外部文件或网络加载新的Java类,或者从内部动态创建新的Java类。
这种动态加载的机制使得Java程序具有更高的灵活性和适应性,可以根据实际情况动态地加载和卸载Java类,使程序更加健壮和高效。
4. 类型映射和自动装箱Java反射机制通常涉及到Java类属性和方法的访问,这就需要将Java类型和反射API 中的类型相互映射。
Java类型和反射API类型之间的映射通常是通过Java的自动装箱和拆箱机制实现的。
这种类型映射机制使得Java反射机制更加方便和易用,让程序员能够更灵活地进行Java类的操作。
反射 field.get()方法(原创版2篇)目录(篇1)1.反射概述2.field.get() 方法的作用3.field.get() 方法的用法4.field.get() 方法的注意事项5.示例代码正文(篇1)1.反射概述在 Java 编程语言中,反射是一种强大的机制,允许程序在运行时检查和修改对象的内部状态。
通过反射,我们可以获取对象的类型信息、调用对象的方法、访问对象的属性等。
反射机制使得程序可以更加灵活,但也会增加一定的开销。
2.field.get() 方法的作用反射中,field.get() 方法用于获取指定对象的公共字段(public fields)或属性(properties)的值。
该方法属于ng.reflect.Field 类,可以通过 Field 类的实例来调用。
3.field.get() 方法的用法要使用 field.get() 方法,首先需要获取 Field 对象。
可以通过以下三种途径获取 Field 对象:(1)通过 Class 类的实例获取:使用 Class 类的 getField() 方法,传入属性名和修饰符作为参数。
(2)通过 Class 加载器获取:使用 Class 加载器的 getField()方法,传入属性名和修饰符作为参数。
(3)通过 Field 类的静态方法获取:使用 Field 类的getDeclaredField() 方法,传入属性名和修饰符作为参数。
获取到 Field 对象后,可以使用 field.get() 方法获取属性值。
需要注意的是,该方法需要传入对象实例作为参数。
如果属性是私有的(private),需要设置 Field 对象的 setAccessible(true) 方法来允许访问。
4.field.get() 方法的注意事项在使用 field.get() 方法时,需要注意以下几点:(1)只有公共字段(public fields)或属性(properties)可以使用 field.get() 方法获取,不能获取私有字段(private fields)。
JAVA反射操作父类所有属性和方法Java反射是一种高级的技术,它允许在运行时动态地获取和操作类的信息。
使用反射技术,可以获取类的构造方法、字段、方法、注解等信息,并且可以动态地创建对象、调用方法、访问属性等。
在Java中,所有的类都直接或间接地继承自Object类。
因此,如果我们要操作一个类的父类的属性和方法,我们首先需要获取该类的父类的Class对象。
通过Class对象,我们可以获取父类的所有公共(public)属性和方法。
要获取父类的Class对象,我们可以使用Class类的`getSuperclass(`方法。
这个方法返回的是一个Class对象,代表了当前类的父类。
下面是一个使用反射获取父类Class对象的示例代码:```javapublic class Child extends Parentpublic static void main(String[] args)Class<?> parentClass = Child.class.getSuperclass(;System.out.println(parentClass.getName();}```运行这段代码,将会输出`Parent`,表示Child类的父类是Parent 类。
获取了父类的Class对象之后,我们可以使用Class对象的`getDeclaredFields(`方法获取所有的字段,`getDeclaredMethods(`方法获取所有的方法。
这两个方法返回的是一个数组,包含了所有字段或方法的信息。
下面是一个获取父类所有字段和方法的示例代码:```javapublic class Parentprivate String privateField;protected String protectedField;public String publicField;private void privateMethoSystem.out.println("Private method");}protected void protectedMethoSystem.out.println("Protected method");}public void publicMethoSystem.out.println("Public method");}public class Child extends Parentpublic static void main(String[] args)Class<?> parentClass = Child.class.getSuperclass(;Field[] fields = parentClass.getDeclaredFields(;for (Field field : fields)System.out.println(field.getName();}Method[] methods = parentClass.getDeclaredMethods(;for (Method method : methods)System.out.println(method.getName();}}```运行这段代码,将会输出父类的所有字段和方法的名称。
java反射的底层原理Java反射是指程序在运行时可以获取自身的信息并操作自身的能力。
它允许程序在运行时分析和修改自身的行为。
反射机制是Java语言的一个重要特性,使得程序可以在运行时检查类、接口、字段和方法,并可以在运行时实例化对象、调用方法和修改属性。
Java反射的底层原理是基于Java的类加载机制和字节码的运行时解析。
在Java中,首先需要通过类的全限定名来获取对应的Class对象。
这可以通过`Class.forName(`方法来实现。
Class对象是Java中用于表示类型信息的重要对象。
通过Class对象,我们可以获取类的属性、方法、构造函数等信息。
Java的类加载机制是反射的重要基础。
在程序运行时,JVM通过类加载器将字节码文件加载到内存中,并创建对应的Class对象。
加载过程中,JVM会进行类的验证、准备和解析操作。
在Java中,字节码是一种中间形式的代码,它是由Java源代码编译生成的。
字节码文件中包含了类的结构信息,包括类的成员变量、方法等。
在运行时,JVM会解析字节码文件,并将其转换成对应的机器指令执行。
反射机制就是基于这种字节码的运行时解析实现的。
反射的底层原理可以分为两个主要阶段:查找和执行。
查找阶段是指根据需要查找需要调用的对象或成员。
在查找阶段,JVM会首先检查类的缓存,如果发现该类已经加载过,则直接返回对应的Class对象;如果缓存中不存在该类,则通过类加载器加载字节码文件,并创建对应的Class对象。
执行阶段是指执行具体的操作,包括实例化对象、调用方法和修改属性等。
在执行阶段,JVM会根据Class对象的信息,动态创建对象,通过反射调用方法和修改属性。
调用方法时,JVM会根据方法的名称和参数类型,查找对应的方法,然后执行对应的机器指令。
反射机制的核心是`ng.reflect`包中的相关类和接口。
这些类和接口提供了获取和操作类的属性、方法和构造函数等能力。
其中,`Class`类表示一个类或接口的类型信息,`Method`类表示一个方法的信息,`Field`类表示一个变量的信息,`Constructor`类表示一个构造函数的信息。
一、介绍Java反射的概念和原理Java反射是指在程序运行时,动态地获取类的信息、调用类的方法和修改类的属性。
通过反射,我们可以在程序运行时动态地创建对象、调用方法和访问属性,而不需要在编译时知道类的类型。
这为程序的灵活性和扩展性提供了很大的便利。
二、Java反射的基本用法1. 获取类的信息通过Java反射,我们可以获取类的各种信息,包括类的名称、父类、接口、构造方法、成员方法、成员变量等。
这些信息可以帮助我们了解类的结构和组成,从而做出相应的操作。
2. 创建对象使用反射,我们可以在运行时动态地创建对象,而不需要在编译时知道类的具体类型。
通过获取类的构造方法,我们可以实例化对象并进行操作。
3. 调用方法通过反射,我们可以动态地调用类的方法。
无论方法是公有的还是私有的,我们都可以使用反射来调用它们。
4. 访问属性反射还可以用于动态地访问和修改类的属性。
我们可以获取类的字段,并且对其进行读写操作。
三、实现Java反射调用impl的方法在实际的应用中,我们经常会遇到需要使用反射调用impl的方法的情况。
下面我们将介绍如何实现这一过程。
1. 获取类的Class对象要使用反射调用impl的方法,首先需要获取类的Class对象。
可以使用Class类的forName方法来获取类的Class对象,也可以通过类的实例对象调用getClass方法来获取Class对象。
2. 创建类的实例在获取到Class对象之后,我们可以通过Class对象的newInstance 方法来创建类的实例。
如果需要调用的方法是静态方法,则可以直接通过Class对象调用方法,不需要创建类的实例。
3. 获取方法对象通过Class对象的getMethod方法或getDeclaredMethod方法来获取类的方法对象。
getMethod方法只能获取公有的方法,而getDeclaredMethod方法还可以获取私有的方法。
4. 调用方法获取到方法对象之后,就可以使用invoke方法来调用方法。
第一节Class一、概述:1、Class是Java程序中各个Java类的总称;它是反射的基石,通过Class类来使用反射。
2、Class和class的区别1)class:Java中的类用于描述一类事物的共性,该类事物有什么属性,没有什么属性,至于这个属性的值是什么,则由此类的实例对象确定,,不同的实例对象有不同的属性值。
2)Class:指的是Java程序中的各个Java类是属于同一类事物,都是Java程序的类,这些类称为Class。
例如人对应的是Person类,Java类对应的就是Class。
3、属性:类名,类的访问属性,类所属包名,字段名称列表,方法名称列表等。
二、对象的创建和使用:1、创建实例对象:不可用new Class()的方式,因为Class没有这样的构造方法。
而是将字节码对象赋值给Class变量。
如Class c1 = Person.class。
如Person类,它的字节码:首先要将Person的java文件编译为class文件放于硬盘上,即为二进制代码,再将这些代码加载到内存中,接着用它创建一个个对象。
就是把类的字节码加载进内存中,再用此字节码创建一个个对象。
当有如Person、Math、Date等等的类,那么这些字节码就是分别的一个Class对象。
即Class c2 = Date.class;。
2、获得类的字节码对象:如Class.forName(”ng.String”)即获得String.class。
得到这个字节码对象有两种情况:1)此类已经加载进内存:若要得到此类字节码,不需要再加载。
2)此类还未加载进内存:类加载器加载此类后,将字节码缓存起来,forName()方法返回加载进来的字节码。
3、得到各字节码对应的实例对象(Class类型)的方式:1)类名.class:如System.class,String.class等等2)对象.class:如new Date().getClass()或者d.getClass()。
(Date d = new Date())3)Class.forName(“类名”):如Class.forName(”ng.String”)当获取类名的时候,是不知道此类的名称的,forName(字符串参数)方法中传入字符串型的变量作为对外访问的入口,即传入什么类名就获得什么类名,从而得知相应的类名。
注:forName()是静态方法,是反射中使用的一种方式获取字节码的实例对象。
每个类的字节码对象只有唯一的一个,如任何字符串对象,对应唯一的String.clas字节码。
4、九个预定义的Class:1)包括八种基本类型(byte、short、int、long、float、double、char、boolean)的字节码对象和一种返回值为void类型的void.class。
2)Integer.TYPE是Integer类的一个常量,它代表此包装类型包装的基本类型的字节码,所以和int.class是相等的。
基本数据类型的字节码都可以用与之对应的包装类中的TYPE常量表示数组类型的Class实例对象,可以用Class.isArray()方法判断是否为数组类型的。
5、总结:只要是在源程序中出现的类型都有各自的Class实例对象,如int[].class、void.class 等。
三、方法:1、static Class forName(String className)---> 返回与给定字符串名的类或接口的相关联的Class对象。
2、Class getClass()---> 返回的是Object运行时的类,即返回Class对象即字节码对象3、Constructor getConstructor()---> 返回Constructor对象,它反映此Class对象所表示的类的指定公共构造方法。
4、Field getField(String name)---> 返回一个Field对象,它表示此Class对象所代表的类或接口的指定公共成员字段。
5、Field[] getFields()---> 返回包含某些Field对象的数组,表示所代表类中的成员字段。
6、Method getMethod(String name,Class… parameterTypes)---> 返回一个Method对象,它表示的是此Class对象所代表的类的指定公共成员方法。
7、Method[] getMehtods()返回一个包含某些Method对象的数组,是所代表的的类中的公共成员方法。
8、String getName()---> 以String形式返回此Class对象所表示的实体名称。
9、String getSuperclass()---> 返回此Class所表示的类的超类的名称10、boolean isArray()---> 判定此Class对象是否表示一个数组11、boolean isPrimitive()---> 判断指定的Class对象是否是一个基本类型。
12、T newInstance()---> 创建此Class对象所表示的类的一个新实例。
示例:public static void fuction()throws Exception{String str1 = "abc";Class cls1 = str1.getClass();Class cls2 = String.class;Class cls3 = Class.forName("ng.String");System.out.println(cls1 == cls2);//trueSystem.out.println(cls1 == cls3);//true//判断是否为基本类型:isPrimitive()System.out.println(cls1.isPrimitive());//falseSystem.out.println(int.class == Integer.class);//false//Integer.TYPE代表包装类对应的基本数据类型的字节码System.out.println(int.class == Integer.TYPE);//trueSystem.out.println(int[].class.isPrimitive());//false//判断是否为数组类型的System.out.println(int[].class.isArray());//true}第二节反射1、概述:把Java类中的各种成分映射成相应的Java类。
如Class中的每一个方法返回的都是一种类(型),即Method对所有方法抽取成了这个类Method,它的每一个对象(如变量methodObj1)代表了一个方法。
2、一个类中的组成成分:成员变量、方法、构造函数、包等信息,也用一个个java类来表示(如汽车是一个类,其中的发动机,变速箱等也是对应的一个个类),表示Java类的Class类显然要提供一系列的方法来获取其中的变量、方法、构造函数、修饰符、包等信息,这些信息就是用相应的类的实例对象来表示,他们是Field、Method、Contructor、Package等。
3、一个类中的每个成员都可用相应的反射API类的一个实例对象来表示,通过调用Class 类的方法可得到这些实例对象。
第三节反射中的各种类一、Constructor类1、概述:Constructor代表某个类的构造方法2、获取构造方法:1)如何得到摸个类的所有构造方法:如得到String类的所有构造方法Constructor[] cons = Class.forName(“ng.String”).getConstructors();2)获取某一个构造方法:Constructor con = String.class.getConstructor(StringBuffer.class);①3、创建实例对象:1)通常方式:String str = new String(new StringBuffer (”abc”));2)反射方式:String str = (String)con.newInstance(new StringBuffer(“abc”));②调用获得的方法时要用到上面相同类型的实例对象,即两个StringBuffer()要对应相等。
NewInstance():构造出一个实例对象,每调用一次就构造一个对象。
注意:上面的两个地方①②都要用到StringBuffer,这必须是一致的。
第①个是指定要带StringBuffer参数类型的构造方法,即所需使用的是含StringBuffer类型的构造方法。
第②个是用这个构造方法创建对象,要传入的参数类型是StringBuffer。
4、Class.newInstance():创建一个对象,不带参数的构造方法。
演示://new String(new StringBuffer("abc"));Constructor constructor1 =String.class.getConstructor(StringBuffer.class);String str2 =(String)constructor1.newInstance(new StringBuffer("abc"));System.out.println(str2);//Class.newInstrance创建不带参数的构造方法String str3 =(String)Class.forName("ng.String").newInstance();System.out.println("str3:"+str3);二、Field类1、概述:Field类代表成员变量(字段)的反射。
示例:public class ReflectPoint {private int x;public int y;public String toString(){return str1+";" + str2 + ";" + str3;}}public class FieldTest(){ReflectPoint pt1 = new ReflectPoint(3,5);//fieldX和fieldY并不是对象身上的变量,而是类上的//要用它去取某个对象上的对应的值,传入什么对象,就取相应对象的值。
Field fieldY = pt1.getClass().getField("y");System.out.println(fieldY.get(pt1));//获取私有的成员变量Field fieldX = pt1.getClass().getDeclaredField("x");fieldX.setAccessible(true);System.out.println(fieldX.get(pt1));}2、获取成员变量:如上例子所示:1)获取公有的成员变量:getField(String name)和get(变量)2)获取私有的成员变量:暴力反射getDeclared(String name)setAccessible(boolean b),将b设为true即可get(变量)//替换字符private static void changeStringValue(Object obj) throws Exception { Field[] fields = obj.getClass().getFields();for(Field field : fields){//此处需要用==比较,因为是同一份字节码对象if(field.getType() == String.class){String oldValue = (String)field.get(obj);String newValue = oldValue.replace('b','a');field.set(obj, newValue);}}}三、Method类1、概述:Method类代表某个类中的一个成员方法。