zoukankan      html  css  js  c++  java
  • 常见设计模式解析和实现(C++)Adapt模式

    作用:将一个类的接口转换成客户希望的另一个接口。Adapt模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。

     

     

    UML示意图

    1)      采用继承原有接口类的方式


     

    2)采用组合原有接口类的方式


     

    解析:

    Adapt模式其实就是把完成同样一个功能但是接口不能兼容的类桥接在一起使之可以在一起工作,这个模式使得复用旧的接口成为可能。

    实现:

    Adapt模式有两种实现的方法,一种是采用继承原有接口的方法,一种是采用组合原有接口类的方法,这里采用的是第二种实现方法

    1)  Adapt.h

     

    1. class Target  
    2. {  
    3. public:  
    4.     Target(){}  
    5.     virtual ~Target(){}  
    6.   
    7.     virtual void Request() = 0;  
    8. };  
    9.   
    10.   
    11. // 与被Adapt对象提供不兼容接口的类  
    12. class Adaptee  
    13. {  
    14. public:  
    15.     Adaptee(){}  
    16.     ~Adaptee(){}  
    17.     void SpecialRequest();  
    18. };  
    19.   
    20.   
    21. // 进行Adapt的类,采用聚合原有接口类的方式  
    22. class Adapter : public Target  
    23. {  
    24. public:  
    25.     Adapter(Adapter* pAdaptee);  
    26.     virtual ~Adapter();  
    27.   
    28.     virtual void Request();  
    29. private:  
    30.     Adaptee* m_pAdatee;  
    31. };  

    (2)Adapt.cpp

    1. #include "Adapt.h"  
    2. #include <iostream>  
    3.   
    4. void Adaptee::SpecialRequest()  
    5. {  
    6.     std::cout << "SpecialRequest of Adaptee ";  
    7. }  
    8.   
    9.   
    10. void Adapter::Adapter(Adaptee *pAdaptee) : m_pAdaptee(pAdaptee)  
    11. {  
    12. }  
    13.   
    14. Adapter::~Adapter()  
    15. {  
    16.     delete m_pAdaptee;  
    17.     m_pAdaptee = NULL;  
    18. }  
    19.   
    20. void Adapter::Request()  
    21. {  
    22.     std::cout << "Request of Adapter ";  
    23.     m_pAdapter->SpecialRequest();  
    24. }  


     (3)main.cpp

    1. #include "Adapter.h"  
    2. #include "stdlib.h"  
    3.   
    4. int main()  
    5. {  
    6.     Adaptee *pAdaptee = new Adaptee;  
    7.     Target  *pTarget  = new Adapter(pAdaptee);  
    8.     pTarget->Request();  
    9.   
    10.     delete pTarget;  
    11.     system("pause");  
    12. }  
  • 相关阅读:
    L3-015. 球队“食物链”【DFS + 剪枝】
    L3-002. 堆栈【主席树 or 线段树 or 分块】
    PTA L1-006 连续因子【暴力模拟】
    【路由和交换之H3C自导自演】
    【ospf-stub区域配置】
    【ospf-链路验证】
    【ospf-vlink虚拟连接】
    【c学习-14】
    【c学习-13】
    【php学习-5】
  • 原文地址:https://www.cnblogs.com/redrainblog/p/4209733.html
Copyright © 2011-2022 走看看