适用性,在以下情况下应当使用装饰模式:
1.需要扩展一个类的功能,或给一个类增加附加责任。
2.需要动态地给一个对象增加功能,这些功能可以再动态地撤销。
3.需要增加由一些基本功能的排列组合而产生的非常大量的功能,从而使继承关系变得不现实。
Decorator模式采用对象组合而非继承的手法,实现了在运行时动态的扩展对象功能的能力,而且可以根据需要扩展多个功能,避免了单独使用继承带来的“灵活性差”和“多子类衍生问题”。同时它很好地符合面向对象设计原则中“优先使用对象组合而非继承”和“开放-封闭”原则。
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() { //......实现了记录优先级别 } }
调用
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");