代理在程序开发中有种非常重要的作用,比如用得比较多的AOP
,就是针对代理的一种应用。此外,在设计模式中,还有一个”代理模式”。在公司里面要上外网,要在浏览器里设置一个Http
代理,代理无处不在。
下面下来看看一个Hello Word
程序:
public interface Hello {
public void say(String name);
}
上面是一个接口,以下是实现类:
public class HelloImpl implements Hello {
@Override
public void say(String name) {
System.out.println("Hello! " + name);
}
}
如果要在println方法前面和后面分别需要处理一些逻辑,如何做呢?把这些方法写死在say
方法里面吗?这样做肯定可以,但是不够优雅。我们要用代理模式,写一个HelloProxy
类,让它去调用HelloImpl的say方法,在调用的前后分别进行逻辑,代码如下:
public class HelloProxy implements Hello {
private Hello hello;
public HelloProxy() {
hello = new HelloImpl();
}
@Override
public void say(String name) {
before();
hello.say(name);
after();
}
private void before() {
System.out.println("Before...");
}
private void after() {
System.out.println("After...");
}
}
用HelloProxy
类实现了Hello
接口(和HelloImpl实现相同的接口),并且在构造方法中new出一个HelloImpl
类的实例。这样一来,就可以在HelloProxy
的say
方法里面去调用HelloImpl
的say
方法了。更加重要的是。还可以在调用的前后分别加上before
和after
方法,在这两个方法里去实现那些前后逻辑。
下面用一个main方法来测试一下:
public class Main {
public static void main(String[] args) {
Hello helloProxy = new HelloProxy();
helloProxy.say("longjiazuo");
}
}
运行后,打印结果如下:
Before...
Hello! longjiazuo
After...
轻而易举,就写出了这么优雅的代码,心里暗自高兴。这就是所谓的”代理模式”,这么看来,自己和Gof的距离又接近了一点。但是你会发现,这样写的代码是”死”代码,这种代理模式被称为”静态代理”,实际的项目中我们要学会使用动态代理,接下来的文章会说说JDK
的动态代理和CGlib
动态代理。
如果有更多技术问题,可以关注我的公众号给我留言