反射
动态加载类
//Class.forName通过类名返回一个类的元类型
Class clz = Class.forName("User");
实例化类
访问类的成员
Object obj = clz.newInstance();//调用默认的构造方法
Class objArgs[] = {int.class,String.class,int.class};
Constructor objCons = clz.getDeclaredConstructor(objArgs);//调用指定参数类型的构造方法
Object obj1 = objCons.newInstance(2,"Pang niu",26);
--示例
--Bean类
public class User {
private int id;
private int age;
private String name;
public User(){}
public User(int id,String name,int age){
this.id = id;
this.name = name;
this.age = age;
}
public int getAge() {
return age;
}
private void setAge(int age) {
this.age = age;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String toString(){
return "ID:"+this.id+" NAME:"+this.name+" Age:"+this.age;
}
}
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
public class Main {
/**
* @param args
* @throws ClassNotFoundException 类不存在的异常
* @throws IllegalAccessException 非法访问异常
* @throws InstantiationException 实例化异常,比如构造函数为PRIVATE
* @throws NoSuchMethodException
* @throws SecurityException
* @throws InvocationTargetException
* @throws IllegalArgumentException 非法参数异常
*/
public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException, SecurityException, NoSuchMethodException, IllegalArgumentException, InvocationTargetException {
//动态加载类
//Class.forName通过类名返回一个类的元类型
Class clz = Class.forName("User");
Object obj = clz.newInstance();//调用默认的构造方法
Method mSetId = clz.getMethod("setId", int.class);//必须指定方法的参数类型,得到唯一的方法。只能访问Public的方法
mSetId.invoke(obj, 1);
Method mSetName = clz.getMethod("setName", String.class);
mSetName.invoke(obj, "Anker");
// Method mSetAge = clz.getMethod("setAge", int.class);//方法为private,无法访问,只能访问public修饰
Method mSetAge = clz.getDeclaredMethod("setAge", int.class);//
mSetAge.setAccessible(true);//针对缺少可视性的方法,设置为可以访问
mSetAge.invoke(obj, 27);
System.out.println(obj.toString());
Class objArgs[] = {int.class,String.class,int.class};
Constructor objCons = clz.getDeclaredConstructor(objArgs);
Object obj1 = objCons.newInstance(2,"Pang niu",26);
System.out.println(obj1);
}
}
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
public class Main2 {
/**
* @param args
* @throws ClassNotFoundException 类不存在的异常
* @throws IllegalAccessException 非法访问异常
* @throws InstantiationException 实例化异常,比如构造函数为PRIVATE
* @throws NoSuchMethodException
* @throws SecurityException
* @throws InvocationTargetException
* @throws IllegalArgumentException 非法参数异常
* @throws NoSuchFieldException
*/
public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException, SecurityException, NoSuchMethodException, IllegalArgumentException, InvocationTargetException, NoSuchFieldException {
//动态加载类
//Class.forName通过类名返回一个类的元类型
Class clz = Class.forName("User");
Object obj = clz.newInstance();
// Field fId = clz.getField("id"); //只能访问public的属性,否者报错Java.Lang.NoSuchFileException
// Field fName = clz.getField("name");
Field fId1 = clz.getDeclaredField("id"); //只能访问public的属性,除非setAccessible来访问protected或者private的权限
Field fName1 = clz.getDeclaredField("setAge");
fId1.setAccessible(true);
fName1.setAccessible(true);
fId1.set(obj, 1);
fName1.set(obj, "Anker");
System.out.println(obj);
}
}
一些重要的反射API
public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException, SecurityException, NoSuchMethodException, IllegalArgumentException, InvocationTargetException, NoSuchFieldException {
//动态加载类
//Class.forName通过类名返回一个类的元类型
Class clz = Class.forName("User");
Method[] mthods = clz.getMethods();//获得所有的方法,包括从父类继承的方法
for(Method m:mthods){
if(m.getDeclaringClass() == clz){ //查询本类定义的方法
System.out.println(m);
if(Modifier.isStatic(m.getModifiers())){//判断方法是否是static
System.out.println();//
}
System.out.println(m.getModifiers());//以整型代表方法的修饰符
}
}
}
反射与动态代码
Java 提供的动态代码的实现,为代理类与实现类继承同一个接口,针对接口要实现的方法可以实现动态代理。
package DymaticProxy;
public interface IWork {
public void run();
}
package DymaticProxy;
public class Worker implements IWork{
public void run() {
System.out.println("in work run");
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
package DymaticProxy;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class LoggerProxy implements InvocationHandler {
Object target = null;
public Object newProxyInstance(Object targetObject) {
target = targetObject;
return Proxy.newProxyInstance(targetObject.getClass().getClassLoader(),
target.getClass().getInterfaces(), this);
}
@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
System.out.println("start-->>" + method.getName());
try {
method.invoke(target, args);
System.out.println("success-->" + method.getName());
} catch (Exception ex) {
ex.printStackTrace();
System.out.println("error-->>" + method.getName());
throw ex;
}
return null;
}
}
JDK的动态代理机制只能代理实现了接口的类,而不能实现接口的类就不能实现JDK的动态代理,
CGlib 实现代理类与实现类可以不继承相同接口,通过创建继承代理类,来实现动态代理,
它的原理是对指定的目标类生成一个子类,并覆盖其中方法实现增强,
但因为采用的是继承,所以不能对final修饰的类进行代理。
具体查看附件。
相关推荐
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反射是Java编程语言中的一个强大特性,它允许运行时的程序访问并操作类、接口、字段和方法等信息,即使这些信息在编译时并未明确知晓。在Java中,反射通常通过`java.lang.Class`类和相关的API来实现。本实例将...
### Java反射机制详解 #### 一、概述 Java反射机制是一种强大的编程技术,它允许运行时检查类的信息并操作对象的内部结构。本篇将基于Sun公司的官方文档《Java™ Core Reflection API and Specification》(1997年...
### 反射实例—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)是一种强大的工具,它允许程序在运行时访问类的信息,并能够动态地创建对象、调用方法以及获取字段值等。这种能力对于框架设计、代码...