- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
黑马程序员--学习笔记之Java动态代理
动态代理
什么是代理?
已知一个目标类具有某些功能,要增加这个类的一些功能,但又不能修改原来的类代码,这时就可以通过静态或者动态的方式创建这个目标类的代理类,具备之前的功能外还能增加额外的功能。
代码演示:继承和装饰模式进行静态代理。
//接口
interface Demo{
abstract void show();
}
//目标类通过实现这个接口具备功能
class SubjectDemo implements Demo{
public void show(){
System.out.println(Demo is show);
}
}
//继承的方式创建代理类
class DemoProxy extends SubjectDemo{
@Override
public void show() {
System.out.println(DemoProxy is show before);
super.show();
System.out.println(DemoProxy is show after);
}
}
// 装饰的方式创建代理类
class DemoProxy implements Demo{
private Demo demo;
private DemoProxy(Demo demo) {
super();
this.demo = demo;
}
@Override
public void show() {
System.out.println(DemoProxy is show before);
demo.show();
System.out.println(DemoProxy is show after);
}
}
上述两种创建代理类的实现都是属于静态代理,都比较局限,当目标类SubjectDemo实现更多的接口又增加了新的功能时,又要手动的创建更多的代理类来额外增加功能。
什么是动态代理?
JVM可以在运行期动态生成出类的字节码,这种动态生成的类往往被用作代理类,即动态代理类,这样的实现过程称之为动态代理。JVM生成的动态类必须实现一个或多个接口,所以,JVM生成的动态类只能用作具有相同接口的目标类的代理。如果动态类没有实现接口,CGLIB库可以动态生成一个类的子类,一个类的子类也可以用作该类的代理,所以,如果要为一个没有实现接口的类生成动态代理类,那么可以使用CGLIB库。代理类的各个方法中通常除了要调用目标的相应方法和对外返回目标返回的结果外,还可以在代理方法中的如下四个位置加上系统功能代码:
(1)在调用目标方法之前
(2)在调用目标方法之后
(3)在调用目标方法前后
(4)在处理目标方法异常的catch块中
3.怎样实现动态代理,创建动态代理类?
在java中,动态代理同基于 Proxy和InvocationHandler 两个类来完成的,使用JAVA反射机制。
Proxy类提供用于创建动态代理类和实例的静态方法,它还是由这些方法创建的所有动态代理类的超类。可以通过反射方式创建目标类的动态代理类。
Proxy构造方法:
protected Proxy(InvocationHandler h)
使用其调用处理程序指定值从子类(通常为动态代理类)构建新的 Proxy 实例。
Proxy一般方法:
Class? getProxyClass(ClassLoader loader, Class?... interfaces)
传入代理类的类加载器,目标类的接口的Class实例(可有多个),返回代理类的Class实例
Object newProxyInstance(ClassLoader loader, Class?[] interfaces, InvocationHandler h)
前面传入的两个参数和上述的方法中一样的,最后传入的是一个InvocationHandler接口的子类对象,需要自定义,覆写invoke方法。
InvocationHandler 是代理实例的调用处理程序实现的接口。每个代理实例都具有一个关联的调用处理程序。对代理实例调用方法时,将对方法调用进行编码并将其指派到它的调用处理程序的 invoke 方法。
InvocationHandler 接口的抽象方法:
Object invoke(Object proxy,Method method,Object[] args)
传入第一个参数就是代理类,第二个参数是目标类的对应一般方法反射对应的方法对象,第个参数就是要调用的那个方法的参数(是用数组表示,参数可以是多个),返回的就是调用这个方法后返回的结果,如果没有返回值就返回null。如果覆写,那么方法体是什么呢?其实调
文档评论(0)