说到代理,大家肯定都有接触过。毕竟当有些事务不想亲自处理时,会选择委托给别人进行解决。那么在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
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)