《设计模式》书上举的例子是Graphic-Picture,但我觉得这里用“文件夹-文件”最直观。
文件夹里能包括文件夹和文件, 文件是“Leaf”子类,文件夹是“Composite”类。当需要遍历文件夹的时候,用这样一种“递归”的关系是很优雅的方式。
一般Composite类都包含一个List
我目前理解这个模式的核心就是“递归”。
另外有一个模式“Decorator”和这个有点像,但Decorator一般不会有List容器,而是只包含一个子类对象的指针。除了用途不一样外,用法上基本是嵌套很多new。
例如:Stream* aStream = new CompressingStream(new ASCII7Stream(new FileStream(“aFileName”)));
这个模式以后再说。
最新评论