在静态代理中代理对象与被代理对象(目标对象)必须实现同一个接口,完整保留被代理对象的接口样式,也将接口不变的原则一直保留。
下面通过一个简单的示例来说明:
HelloInterface接口
package proxy;public interface HelloInterface {public void sayHello();
}
package proxy;public class HelloInterfaceImpl implements HelloInterface {@Overridepublic void sayHello() {System.out.println("Hello xianjj");}}
用于增强实现类HelloInterfaceImpl功能的类(代理)proTest
package proxy;public class ProTest implements HelloInterface {HelloInterface helloInterface;public ProTest(HelloInterface helloInterface) {super();this.helloInterface = helloInterface;}@Overridepublic void sayHello() {System.out.println("准备");helloInterface.sayHello();System.out.println("结束");}public static void main(String[] args) {HelloInterface pro = new proTest(new HelloInterfaceImpl());pro.sayHello();}
}
ProTest类实现了HelloInterface接口,并且构造方法的参数类型也是HelloInterface,这样ProTest具有实例变量helloInterface,这样就知道代理类的具体实现了,主要是使用proTest类对HelloInterfaceImpl的功能进行“包装”;最后通过main方法进行输出,结果如下截图。
在不改变原有类HelloInterfaceImpl的基础上对其进行功能性增强,在Hello xianjj的前后分别输出“准备”,‘结束’字样,这就是一个典型的日志或事务的AOP功能模型。从这里可以看到静态代理类自身的主要缺点,即扩展性不好,如果想代理更多的类,就需要创建更多的代理类。
在本例中proTest是代理类,HelloInterfaceImpl就是被代理的对象。
转载于:.html
本文发布于:2024-01-29 13:00:41,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170650444515464.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |