动态地给一个对象添加一些额外的职责。就扩展功能而言,Decorator模式比生成子类方式更为灵活。
以.NET Framework 2.0 System.IO中类为例
System.IO.Stream
public abstract class Stream : MarshalByRefObject, IDisposable
{
//
public abstract int Read([In, Out] byte[] buffer, int offset, int count);
public abstract void Write(byte[] buffer, int offset, int count);
//
}
System.IO.MemoryStream
public class MemoryStream : Stream
{
//
public MemoryStream(byte[] buffer)
{
//
}
//
public override int Read([In, Out] byte[] buffer, int offset, int count)
{
//
}
public override void Write(byte[] buffer, int offset, int count)
{
//
}
}
System.IO.FileStream
public class FileStream : Stream
{
//
public FileStream(String path, FileMode mode)
{
//
}
//
public override int Read([In, Out] byte[] buffer, int offset, int count)
{
//
}
public override void Write(byte[] buffer, int offset, int count)
{
//
}
}
System.IO.BufferedStream
public class BufferedStream : Stream
{
//
private Stream _s;
//
public BufferedStream(Stream stream)
{
//
}
//
public override int Read(byte[] buffer, int offset, int count)
{
//
_s.Read();
//
}
public override void Write(byte[] buffer, int offset, int count)
{
//
_s.Write();
//
}
}
调用代码
public class Client
{
public static void Main()
{
FileStream stream = new FileStream(@"c:\C:WINDOWSsystem32driversetcservices", FileMode.Open);
BufferedStream bufferedStream = new BufferedStream(stream, 1024);
}
}
在.NET Framework中,所有的流操作都有一个共同的基类System.IO.Stream,它是一个抽象类,主要包含了Read、Write等行为。针对文件流和内存流的操作,定义了FileStream和MemoryStream类,都继承Stream类》直鹗迪植煌的读写操作。为了提高流的读写性能,需要使用缓存Buffer来存放流数据。此时,Buffer的作用对于流的读写操作而言,就相当于一个装饰的作用。
在以下情况下应当使用装饰模式:
1.需要扩展一个类的功能,或给一个类增加附加责任。
2.需要动态地给一个对象增加功能,这些功能可以再动态地撤销。
3.需要增加由一些基本功能的排列组合而产生的非常大量的功能,从而使继承关系变得不现实。
版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明!