c++ 装饰器模式/包装模式
理解
使用两个隔离又继承自统一接口类的对象:方法对象(抽象/具体), 包装器对象(抽象/具体)实现多种组合只需要 n + m种实现, 而对比直接继承,则需要n*m 种实现,因此在面对多种具体类和多种额外装饰(额外的操作)时,装饰器模式比较有用,举例说明:
实现流的普通和加解密
n是流: 文件流,网络流,控制台流, m是普通和加密
如果用直接继承的方法处理,则需要实现的对象有文件流普通,文件流加密,网络流普通和网络流加密,,控制台流普通,控制台流加密, 一共是3*2 = 4
而用装饰器模式, 则只需要实现两种流,两种包装器,3+2 = 5 
原因是因为装饰器模式使用运行时绑定
实现
方法类
class StreamBase{
    virtual void io() = 0; 
};
class FileStream:public StreamBase {
    void io(){
        // impletation
    }
};
class SocketStream:public StreamBase {
    void io(){
        // impletation
    }
};
class ConsoleStream:public StreamBase {
    void io(){
        // impletation
    }
};
包装类
class DecoderBase: public StreamBase {
public
    DecoderBase(StreamBase * ptr):m_functionbase(ptr){}
  void io(){
       m_functionbase->io();
    }
private:
    StreamBase* m_functionbase;
};
class NormalDecoder :public DecoderBase{
public:
    NormalDecoder (StreamBase * ptr):DecoderBase(ptr){}
    void io(){
        DecoderBase::io();
        normal();
    }
    
private:
    void normal();
};
class EncodeDecoder :public DecoderBase{
public:
    EncodeDecoder(StreamBase * ptr):DecoderBase(ptr){}
    void io(){
        DecoderBase::io();
        encode();
    }
    
private:
    void encode();
};
分析
包装器要继承方法接口的原因是统一接口。
包装器基类的作用是统一了数据,避免在每个基类里需要重复定义一个方法对象指针
总结
装饰器模式是比较有用的方法,比较灵活处理多变的情况,不过缺点是多重包装器比较复杂
 
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号