适配器模式

适配器模式(Adapter):

       将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。简单地说,就是需要的东西 就在面前,但却不能使用,而短时间又无法改造它,于是就想办法适配它。适配这个词可以这样理解。比如,有些国家用110V电压,而我们国家用的是 220V,但我们的电器,比如笔记本电脑是不能什么电压都能用的,但国家不同,电压可能不相同也是事实,于是就用一个电源适配器,只要是电,不管多少伏, 都能把电源变成需要的电压,这就是电源适配器的作用。适配器的意思就是使得一个东西适合另一个东西的东西。

      在软件开发中,系统的数据和行为都正确,但接口不符合,我们应该考虑用适配器,目的是使控制范围之外的一个原有对象与某个接口匹配。适配器模式主要应用于希望复用一些现存的类,但是接口又与复用环境要求不一致的情况。

何时使用适配器模式:

       使用一个已存在的类,但如果它的接口,也就是它的方法和你的要求不相同时,就应该考虑用适配器模式。也就是两个类所做的事情相同或相似,但是具有不同的接 口时要使用它。而且由于类都共享同一个接口,使得客户端代码可以统一调用同一接口。这样应该可以更简单、更直接、更紧凑。

       适配器模式要在双方都不太容易修改的时候再使用适配器模式适配。

赏图:

实际应用

工程结构

(1)球员类(Target) Player.h

(2)外籍球员类(Adaptee) ForeignCenter.h

(3)翻译类(Adapter) Translator.h

(4)客户端类(Client) AdapterApp.cpp

(1)球员类(Target) Player.h

  1. #ifndef _PLAYER_H_  
  2. #define _PLAYER_H_  
  3.   
  4. #include <string>  
  5. #include <iostream>  
  6. using namespace std;  
  7.   
  8. class Player  
  9. {  
  10. public:  
  11.     Player(const string& strName)  
  12.     {  
  13.         m_strName = strName;  
  14.     }  
  15.   
  16.     virtual void Attack(void) = 0;  // 进攻  
  17.     virtual void Defense(void) = 0; // 防守  
  18. protected:  
  19.     string m_strName;  
  20. };  
  21.   
  22. // 前锋类  
  23. class Forwards : public Player  
  24. {  
  25. public:  
  26.     Forwards(const string& strName)   
  27.         : Player(strName)  
  28.         , m_strName(strName){}  
  29.   
  30.     void Attack(void)  
  31.     {    
  32.         cout << "Forward:" <<m_strName << " attack" << endl;   
  33.     }  
  34.   
  35.     void Defense(void)  
  36.     {    
  37.         cout << "Forward:" <<m_strName << " defense" << endl;   
  38.     }  
  39.   
  40. private:  
  41.     string m_strName;  
  42. };  
  43.   
  44. // 中锋类  
  45. class Center : public Player  
  46. {  
  47. public:  
  48.     Center(const string& strName)   
  49.         : Player(strName)  
  50.         , m_strName(strName){}  
  51.   
  52.     void Attack(void)  
  53.     {    
  54.         cout << "Center:" <<m_strName << " attack" << endl;   
  55.     }  
  56.   
  57.     void Defense(void)  
  58.     {    
  59.         cout << "Center:" <<m_strName << " defense" << endl;   
  60.     }  
  61.   
  62. private:  
  63.     string m_strName;  
  64. };  
  65.   
  66. // 后卫类  
  67. class Guards : public Player  
  68. {  
  69. public:  
  70.     Guards(const string& strName)   
  71.         : Player(strName)  
  72.         , m_strName(strName){}  
  73.   
  74.     void Attack(void)  
  75.     {    
  76.         cout << "Guard:" <<m_strName << " attack" << endl;   
  77.     }  
  78.   
  79.     void Defense(void)  
  80.     {    
  81.         cout << "Guard:" <<m_strName << " defense" << endl;   
  82.     }  
  83.   
  84. private:  
  85.     string m_strName;  
  86. };  
  87.   
  88. #endif// _PLAYER_H_  

(2)外籍球员类(Adaptee) ForeignCenter.h

  1. #ifndef _FOREIGN_CENTER_H_  
  2. #define _FOREIGN_CENTER_H_  
  3.   
  4. #include <string>  
  5. #include <iostream>  
  6. using namespace std;  
  7.   
  8. class ForeignCenter  
  9. {  
  10. public:  
  11.     void SetName(const string& strName){ m_strName = strName; }  
  12.     string GetName(void){ return m_strName; }  
  13.   
  14.     // 外籍中锋只懂中文进攻  
  15.     void ForeignAttack()  
  16.     {  
  17.         cout << "外籍中锋:" <<m_strName << "进攻" << endl;   
  18.     }  
  19.   
  20.     // 外籍中锋只懂中文防守  
  21.     void ForeignDefense()  
  22.     {  
  23.         cout << "外籍中锋:" <<m_strName << "防守" << endl;   
  24.     }  
  25. private:  
  26.     string m_strName;  
  27. };  
  28.   
  29. #endif// _FOREIGN_CENTER_H_  

(3)翻译类(Adapter) Translator.h

  1. #ifndef _TRANSLATOR_H_  
  2. #define _TRANSLATOR_H_  
  3.   
  4. #include "Player.h"  
  5. #include "ForeignCenter.h"  
  6.   
  7. class Translator : public Player  
  8. {  
  9. public:  
  10.     // 声明并实例化一个内部“外籍中锋”对象,表明翻译者与外籍球员有关联  
  11.     Translator(const string& strName)   
  12.         : Player(strName)  
  13.         , m_pForeignCenter(NULL)  
  14.     {  
  15.         m_pForeignCenter = new ForeignCenter();  
  16.         m_strName = strName;  
  17.     }  
  18.   
  19.     ~Translator()  
  20.     {  
  21.         if (NULL != m_pForeignCenter)  
  22.         {  
  23.             delete m_pForeignCenter;  
  24.             m_pForeignCenter = NULL;  
  25.         }  
  26.     }  
  27.   
  28.     // 翻译者将“attack”翻译成“进攻”告诉外籍中锋  
  29.     void Attack(void)  
  30.     {    
  31.         if (NULL != m_pForeignCenter)  
  32.         {  
  33.             m_pForeignCenter->ForeignAttack();  
  34.         }  
  35.     }  
  36.   
  37.     // 翻译者将“Defense”翻译成“防守”告诉外籍中锋  
  38.     void Defense(void)  
  39.     {    
  40.         if (NULL != m_pForeignCenter)  
  41.         {  
  42.             m_pForeignCenter->ForeignDefense();  
  43.         }  
  44.     }  
  45.   
  46. private:  
  47.     ForeignCenter*  m_pForeignCenter;  
  48.     string          m_strName;  
  49. };  
  50.   
  51. #endif// _TRANSLATOR_H_  

(4)客户端类(Client) AdapterApp.cpp

  1. // AdapterApp.cpp : 定义控制台应用程序的入口点。  
  2. //  
  3.   
  4. #include "stdafx.h"  
  5. #include "Player.h"  
  6. #include "Translator.h"  
  7.   
  8. #define FREE_PTR(Pointer)   \  
  9.     {                       \  
  10.         if (NULL != Pointer)\  
  11.         {                   \  
  12.             delete Pointer; \  
  13.             Pointer = NULL; \  
  14.         }                   \  
  15.     }                         
  16.   
  17. int _tmain(int argc, _TCHAR* argv[])  
  18. {  
  19.     Player* pCarter = new Forwards("carter");  
  20.     if (NULL != pCarter)  
  21.     {  
  22.         pCarter->Attack();  
  23.     }  
  24.   
  25.     Player* pKobe = new Guards("Kobe");  
  26.     if (NULL != pKobe)  
  27.     {  
  28.         pKobe->Attack();  
  29.     }  
  30.   
  31.     // 翻译者告诉yao,教练要求你进攻和防守  
  32.     Player* pYao = new Translator("Yao");  
  33.     if (NULL != pYao)  
  34.     {  
  35.         pYao->Attack();  
  36.         pYao->Defense();  
  37.     }  
  38.   
  39.     Player* pOneal = new Center("o'neal");  
  40.     if (NULL != pOneal)  
  41.     {  
  42.         pOneal->Attack();  
  43.     }  
  44.  
     
  45.     FREE_PTR(pOneal);  
  46.     FREE_PTR(pYao);  
  47.     FREE_PTR(pKobe);  
  48.     FREE_PTR(pCarter);  
  49.     return 0;  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值