适用性,在以下情况下应当使用装饰模式:
1.需要扩展一个类的功能,或给一个类增加附加责任。
2.需要动态地给一个对象增加功能,这些功能可以再动态地撤销。
3.需要增加由一些基本功能的排列组合而产生的非常大量的功能,从而使继承关系变得不现实。
Decorator模式采用对象组合而非继承的手法,实现了在运行时动态的扩展对象功能的能力,而且可以根据需要扩展多个功能,避免了单独使用继承带来的“灵活性差”和“多子类衍生问题”。同时它很好地符合面向对象设计原则中“优先使用对象组合而非继承”和“开放-封闭”原则。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | public abstract class Log { public abstract void Write( string log); } public abstract class LogWrapper : Log { private Log _log; public LogWrapper(Log log) { _log = log; } public override void Write( string log) { _log.Write(log); //抽象类也可以有具体实现方法 } } public class LogErrorWrapper : LogWrapper { public LogErrorWrapper(Log _log): base (_log) { } public override void Write( string log) { SetError(); //功能扩展 base .Write(log); //调用上级类的Write方法 } public void SetError() { //实现了记录错误严重级别 } } public class LogPriorityWrapper : LogWrapper { public LogPriorityWrapper(Log _log): base (_log) { } public override void Write( string log) { SetPriority(); //......功能扩展 base .Write(log); } public void SetPriority() { //......实现了记录优先级别 } } |
调用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | Log log = new DatabaseLog(); LogWrapper lew1 = new LogErrorWrapper(log); //扩展了记录错误严重级别 lew1.Write( "Log Message" ); LogPriorityWrapper lpw1 = new LogPriorityWrapper(log); //扩展了记录优先级别 lpw1.Write( "Log Message" ); //多次包装,第一次包装产生lew2,再次包装lew2,产生lpw2 LogWrapper lew2 = new LogErrorWrapper(log); LogPriorityWrapper lpw2 = new LogPriorityWrapper(lew2); //这里是lew2 //同时扩展了错误严重级别和优先级别 lpw2.Write( "Log Message" ); |
分类:
DesignMode(设计模式)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
2016-07-04 MVC Pager使用