装饰者模式(Decorator):
装饰模式指的是在不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。(就相当于IO体系中的缓冲流)
- 注意事项及细节
- 装饰者模式一般用于对原有功能进行增强/装饰
- 动态的将新功能附加到对象上。在对象功能扩展方面,它比继承更有弹性
外观模式(Facade):
为子系统中的一组接口提供一个一致的界面,外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。
注意事项及细节:
1屏蔽了子系统的细节,因此外观模式降低了客户端对子系统使用的复杂性
2对客户端与子系统的耦合关系 - 解耦,让子系统内部的模块更易维护和扩展
3提高了安全性。
缺点:不符合开闭原则,如果要改东西很麻烦,继承重写都不合适
代理模式(Proxy): 为其他对象提供一种代理以控制对这个对象的访问。
有两种状态:
静态:
角色
接口(随便写个接口):
ITeacherDao
目标对象(随便写个类):
TeacherDAO
代理类(随便写个类):
TeacherDAOProxy
细节:
代理对象与目标对象要实现相同的接口
调用的时候通过调用代理对象的方法来调用目标对象
、
动态(分为两种):
jdk代理:
角色
接口(随便写个接口):
ITeacherDao
目标对象(随便写个类):
TeacherDAO
代理类(随便写个类):
TeacherDAOProxy
细节:
不需要实现接口,但是**目标对象要实现接口**,否则不能用动态代理
代理对象的生成,是利用 JDK 的 API,动态的在内存中构建代理对象
代理类所在包:java.lang.reflect.Proxy
Cglib代理:
角色
接口(随便写个接口):
ITeacherDao
目标对象(随便写个类):
TeacherDAO
代理类(随便写个类):
TeacherDAOProxy
细节
目标对象与代理对象都不需要实现接口
Cglib 代理也叫作子类代理,它是在内存中构建一个子类对象从而实现对目标对象功能扩展
Cglib 是一个强大的高性能的代码生成包,它可以在运行期扩展 java 类与实现 java 接口.它广泛的被许多 AOP 的框架使用
Cglib 包的底层是通过使用字节码处理框架 ASM 来转换字节码并生成新的类
(注意:
1)需要引入 cglib 的 jar 文件
2)在内存中动态构建子类,注意代理的类不能为 final,否则报错java.lang.IllegalArgumentException:
3)目标对象的方法如果为 final/static,那么就不会被拦截,即不会执行目标对象额外的业务方法.)
-
-