java代理模式的分类

说到代理,大家肯定都有接触过。毕竟当有些事务不想亲自处理时,会选择委托给别人进行解决。那么在java中也有着这样的机制,叫做代理模式。主要分为两大类:静态代理和动态代理。一种是运行前就存在,另一种是运行后才进行创建。下面我们就java中的两种代理模式进行讲解。

1.静态代理

由程序员创建或者由第三方工具生成,再进行编译;在程序运行之前,代理类的.class文件已经存在了。静态代理通常只代理一个类,并且要事先知道代理的是什么。

publicclassBlogStaticProxyimplementsIBlogService{

privateIBlogServiceblogService;



publicBlogStaticProxy(IBlogServiceblogService){

this.blogService=blogService;

}



@Override

publicvoidwriteBlog(){

System.out.println("startwriting...");

blogService.writeBlog();

System.out.println("endwriting...");

}

}

2.动态代理

动态代理的代理类在程序运行前是不存在的,也就是说代理类在程序运行时才创建的代理模式成为动态代理。这种情况下,代理类并不是在Java代码中定义好的,而是在程序运行时根据我们的在Java代码中的“指示”动态生成的。

publicclassMainClass{
publicstaticvoidmain(String[]args){
//1、创建一个真实角色
Singertarget=newSinger();
//2、调用Proxy.newProxyInstance方法,并构造一个InvocationHandler对象,
//3、在对象内部重写invoke方法,同时调用method.invoke(target,args);
//4、并在该方法的上下添加自己的代码逻辑
//其中:target.getClass().getClassLoader():获取类加载器,用来生成代理对象;
//target.getClass().getInterfaces()获取接口元信息;
ISingeriSinger=(ISinger)Proxy.newProxyInstance(target.getClass().getClassLoader(),target.getClass().getInterfaces(),newInvocationHandler(){
@Override
publicObjectinvoke(Objectproxy,Methodmethod,Object[]args)throwsThrowable{
System.out.println("动态代理---向观众问好");//在真实对象的方法被调用“前”编写自己的业务逻辑
ObjectreturnValue=method.invoke(target,args);//此处通过反射调用真实对象对应的方法;
System.out.println("动态代理---向观众问好");//在真实对象的方法被调用“后”编写自己的业务逻辑
returnreturnValue;
}
});
iSinger.sing();
}
}
//测试结果
"C:\ProgramFiles\Java\jdk1.8.0_211\bin\java.exe""-javaagent:C:\Program.......
动态代理---向观众问好
singasong
动态代理---向观众问好

Processfinishedwithexitcode0
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。