代理模式(Proxy):为其它对象提供一种代理以控制对这个对象的访问。
代理类实现被代理类实现的相同接口,来保证代理类和被代理类功能一致
代理类保存一个被代理类的引用,实际调用改引用来实现接口
接口:
public interface UserService {
boolean sign(String name);
}
被代理类:
public class UserServiceImpl implements UserService {
@Override
public boolean sign(String name) {
try {
Thread.sleep(200);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(name + " signin");
return true;
}
}
代理类:
public class StaticProxy implements UserService {
private UserServiceImpl userServiceImpl;
public StaticProxy(UserServiceImpl userServiceImpl) {
this.userServiceImpl = userServiceImpl;
}
@Override
public boolean sign(String name) {
System.out.println("StaticProxy=>sign start");
long start = System.currentTimeMillis();
boolean result = userServiceImpl.sign(name);
System.out.println("StaticProxy=>sign end, cost " + (System.currentTimeMillis() - start) + "ms");
return result;
}
public static void main(String[] args) {
UserServiceImpl userServiceImpl = new UserServiceImpl();
StaticProxy proxy = new StaticProxy(userServiceImpl);
proxy.sign("cdfive");
}
}
输出结果:
StaticProxy=>sign start
cdfive signin
StaticProxy=>sign end, cost 200ms
这里的StaticProxy
类实现了被代理类UserServiceImpl
相关的接口UserService
,通过一个变量保存了被代理类的引用UserServiceImpl
;
接口实现里,调用UserServiceImpl
的sign方法,并在调用前后打印了日志以及耗时情况。
这种用一个代理类对业务接口的实现类进行包装,称之为静态代理。
优点:简单直观
缺点:如果其他业务接口也需要类似处理,比如打印日志及耗时,按这种方式则需要每个接口类添加一个代理类,并且多个代理类存在代码重复。
原文:https://www.cnblogs.com/cdfive2018/p/10676958.html