设计模式中英文对照

中文 英文
1.工厂方法模式 Factory Method Pattern
2.抽象工厂模式 Abstract Factory Pattern
3.建造者模式 Builder Pattern
4.原型模式 Prototype Pattern
5.单例模式 Singleton Pattern
6.适配器模式 Adapter Pattern
7.桥梁模式/桥接模式 Bridge Pattern
8.组合模式 Composite Pattern
9.装饰模式 Decorator Pattern
10.门面模式/外观模式 Facade Pattern
11.享元模式 Flyweight Pattern
12.代理模式 Proxy pattern
13.责任链模式 Chain of ResponsibilityPattern
14.命令模式 Command Pattern
15.解释器模式 Interpreter Pattern
16.迭代器模式 Iterator Pattern
17.中介者模式 Mediator Pattern
18.备忘录模式 Memento Pattern
19.观察者模式 Observer Pattern
20状态模式 Strategy Pattern
21.策略模式 Strategy Pattern
22.模板方法模式 Template Method Pattern
23.访问者模式 Visitor Pattern

常用设计模式

1.代理模式

角色分析
抽象角色:一般使用接口或者抽象类来解决
真实角色:被代理的角色
代理角色:代理真实角色,一般会有一些附加的操作
客户:访问代理对象
代理模式的好处:
可以是真实角色更加的纯粹,不去关注一些公共的业务
公共业务交给代理角色,实现业务的分工
公共业务发生扩展时,方便集中管理
缺点:
一个真实的角色就会产生一个代理角色,代码量增加,开发效率降低

静态代理

动态代理

1.类图

JDK代理.png

2.动态代理代理模式的基本介绍

1)代理对象,不需要实现接口,但是目标对象要实现接口,否则不能用动态代理
2)代理对象的生成,是利用JDK的API,动态的在内存中构建代理对象
3)动态代理也叫做:JDK代理、接口代理

3.JDK中生成代理模式的API

代理类所在的包是:Java.lang.reflect.Proxy

  1. //classLoader loader :指定当前目标对象使用的类加载器,获取加载器的方法固定
  2. //class<?>[] interfaces:目标对象实现的接口类型,使用泛型方法确认类型
  3. //InvocationHandler h :事情处理,执行目标对象的方法时,会触发事情处理器方法,
  4. 会把当前目标对象的的方法做为参数传入。
  5. public static Object newProxyInstance(ClassLoader loader,
  6. Class<?>[] interfaces,
  7. InvocationHandler h)

4.举例

  1. public interface ITeacher {
  2. public void teach();
  3. }
  4. public class Teacher implements ITeacher{
  5. @Override
  6. public void teach() {
  7. System.out.println("Start Teachering");
  8. }
  9. }
  10. public class JDKproxyFactory {
  11. private Object target;
  12. public JDKproxyFactory(Object target){
  13. this.target = target;
  14. }
  15. public Object getProxyInstance(){
  16. return Proxy.newProxyInstance(target.getClass().getClassLoader(), target.getClass().getInterfaces(), new InvocationHandler() {
  17. @Override
  18. public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
  19. System.out.println("JDK代理开始");
  20. Object invoke = method.invoke(target,args);
  21. return invoke;
  22. }
  23. });
  24. }
  25. }
  26. public class Client {
  27. public static void main(String[] args) {
  28. ITeacher iTeacher = new Teacher();
  29. JDKproxyFactory jdKproxyFactory = new JDKproxyFactory(iTeacher);
  30. ITeacher proxyInstance = (ITeacher) jdKproxyFactory.getProxyInstance();
  31. proxyInstance.teach();
  32. }
  33. }

Cglib代理

1.Cglib代理模式的基本介绍

1)静态代理和DK代理模式都要求目标对象是实现一个接口,但是有时候目标对象只是一个单独的对象,并没有实现任何的接口,这个时候可使用目标对象子类来实现代理-这就是cglib代理
2)Cglib代理也叫作子类代理,它是在内存中构建一个子类对象从而实现对目标对象功能扩展,有些书也将cglib代理归属到动态代理。
3)Cglib是一个强大的高性能的代码生成包,它可以在运行期扩展java类与实现java接口.它广泛的被许多AOP的框架使用,例如Spring AOP,实现方法拦截
4)在AOP编程中如何选择代理模式:
1.目标对象需要实现接口,用JDK代理
2.目标对象不需要实现接口,用Cglib代理
5)Cglib包的底层是通过使用字节码处理框架ASM来转换字节码并生成新的类
注意:在内存中动态构建子类,注意代理的类不能为final,否则报错java.lang.IllegalArgumentException
目标对象的方法如果为final/static,那么就不会被拦截,即不会执行目标对象额外的业务方法.

2.类图

Cglib代理.png
3.举例

  1. public class TeacheDao {
  2. public void teach(){
  3. System.out.println("授课完毕");
  4. }
  5. }
  6. public class ProxyFactory implements MethodInterceptor {
  7. //引入一个对象
  8. private Object target;
  9. public ProxyFactory(Object target) {
  10. this.target = target;
  11. }
  12. public Object getProxyInstance(){
  13. //创建一个工具类
  14. Enhancer enhancer = new Enhancer();
  15. //设置父类
  16. enhancer.setSuperclass(target.getClass());
  17. //设置回调函数
  18. enhancer.setCallback(this);
  19. //创建子类对象,即代理对象
  20. return enhancer.create();
  21. }
  22. //该方法会调用目标对象的方法
  23. @Override
  24. public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable {
  25. System.out.println("Cglib代理开始");
  26. Object invoke = method.invoke(target, objects);
  27. System.out.println("Cglib代理提交");
  28. return invoke;
  29. }
  30. }
  31. public class Client {
  32. public static void main(String[] args) {
  33. TeacheDao teacheDao = new TeacheDao();
  34. TeacheDao proxyInstance = (TeacheDao)new ProxyFactory(teacheDao).getProxyInstance();
  35. proxyInstance.teach();
  36. }
  37. }

代理模式的变体

1)防火墙代理
内网通过代理穿透防火墙,实现对公网的访问。
2)缓存代理
比如:当请求图片文件等资源时,先到缓存代理取,如果取到资源则ok,如果取不到资源,再到公网或者数据 库,然后缓存。
3)远程代理
远程对象的本地代表,通过它可以把远程对象当本地对象来调用。远程代理通过网络和真正的远程对家沟通信 息。
4)同步代理:主要使用在多线程编程中,完成多线程间同步工作