Java中反射动态 代理接口的详解及实例
作者:lqh 时间:2023-11-28 05:29:36
Java语言中反射 * 接口的解释与演示
Java在JDK1.3的时候引入了 * 机制、可以运用在框架编程与平台编程时候捕获事件、审核数据、日志等功能实现,首先看一下设计模式的UML图解:
当你调用一个接口API时候,实际实现类继承该接口,调用时候经过proxy实现。
在Java中 * 实现的两个关键接口类与class类分别如下:
java.lang.reflect.Proxy
java.lang.reflect.InvocationHandler
我们下面就通过InvocationHandler接口来实现 * 过程,通过Proxy接口创建
一个代理类,然后测试完整的程序。要实现演示Demo需要如下几步:
一:首先定义我们自己的POJO对象接口类IExample与IUser
package com.example.pojo;
public interface IExample {
public void setName(String name);
public String getName();
public void setDesc(String description);
public String getDesc();
}
package com.example.pojo;
public interface IUser {
public void setUserID(String userID);
public String getUserID();
public void setUserName(String userName);
public String getUserName();
}
二:实现我们自己InvocationHandler接口,其中map我用来存储POJO对象的数据,这样做的好处是POJO接口无需再创建实现类,只有定义接口就可以通过代理直接使用该类,这在实际项目开发中非常有用。
package com.example.reflection;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.HashMap;
import java.util.Map;
public class MyProxyView implements InvocationHandler {
private Map<Object, Object> map = null;
public static Object newInstance(Class[] interfaces) {
return Proxy.newProxyInstance(MyProxyView.class.getClassLoader(),
interfaces, new MyProxyView());
}
private MyProxyView() {
this.map = new HashMap<Object, Object>();
}
@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
Object result = null;
String methodName = method.getName();
if (methodName.startsWith("get")) {
String name = methodName.substring(methodName.indexOf("get") + 3);
return map.get(name);
} else if (methodName.startsWith("set")) {
String name = methodName.substring(methodName.indexOf("set") + 3);
map.put(name, args[0]);
return null;
} else if (methodName.startsWith("is")) {
String name = methodName.substring(methodName.indexOf("is") + 2);
return (map.get(name));
}
return result;
}
}
三:通过Proxy方法初始化代理得到POJO对象,运行与测试:
package com.example.reflection;
import com.example.pojo.IExample;
import com.example.pojo.IUser;
public class TextProxy {
public static void main(String[] args)
{
IExample example = (IExample)MyProxyView.newInstance(new Class[]{IExample.class});
IUser user = (IUser)MyProxyView.newInstance(new Class[]{IUser.class});
// aduit bean 1
example.setName("my example");
example.setDesc("my proxy example");
// aduit bean 2
user.setUserID("jia20003");
user.setUserName("gloomyfish");
System.out.println("exmaple name : " + example.getName());
System.out.println("exmaple desc : " + example.getDesc());
System.out.println();
System.out.println("user ID : " + user.getUserID());
System.out.println("user name : " + user.getUserName());
}
}
四:运行结果如下:
exmaple name : my example
exmaple desc : my proxy example
user ID : jia20003
user name : gloomyfish
Java * 方式对框架编程非常重要无论是在Web端还是桌面端
而真正把这种技术发扬光大的则是spring框架。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
来源:http://blog.csdn.net/jia20003/article/details/49930043
标签:Java,反射,动态,代理
0
投稿
猜你喜欢
用 FieldMask 提高 C# gRpc 的服务性能
2023-05-03 19:19:05
详解SpringMVC如何进行数据回显
2023-09-12 08:48:15
完美解决SpringCloud-OpenFeign使用okhttp替换不生效问题
2023-07-03 11:27:25
C#基础:Dispose()、Close()、Finalize()的区别详解
2021-10-22 19:20:23
C#操作配置文件app.config、web.config增删改
2022-05-21 01:06:47
Flutter软键盘的原理浅析
2023-10-15 11:18:34
SpringBoot 将配置文件挂到 jar 包外面的操作方法
2023-11-17 11:09:32
SpringBoot+MQTT+apollo实现订阅发布功能的示例
2021-08-30 22:36:46
spring aop之链式调用的实现
2022-10-30 05:56:50
SpringBoot-JPA删除不成功,只执行了查询语句问题
2022-09-10 04:13:55
Android中多个ContentProvider的初始化顺序详解
2021-11-06 03:52:36
Java设计者模式简单工厂模式解析
2023-02-07 14:02:54
基于C#实现磁性吸附窗体
2022-09-04 07:04:51
Spring框架基于注解开发CRUD详解
2021-08-04 03:39:03
springboot 整合hbase的示例代码
2023-02-11 19:35:20
FFmpeg Principle分析Out put File 数据结构
2023-02-17 08:26:49
C#实现的Win32控制台线程计时器功能示例
2022-12-19 20:29:20
深入了解java.util.Arrays的使用技巧
2023-01-10 18:01:32
Android实现照片墙效果的实例代码
2023-01-20 16:53:37
Java 实战项目锤炼之小区物业管理系统的实现流程
2021-07-17 09:24:01