## 适配器模式定义
将一个类的接口转换成客户希望的另外一种接口。适配器模式使得原来由于接口不兼容而不能一起工作的那些类可以一起工作。
## 适配器模式的功能
适配器模式的主要功能是进行转换匹配,目的是复用已有的功能,而不是来实现新的接口。也就是说,客户端需要的功能应该是已经实现好的,不需要适配器模式来实现,适配器模式主要负责把不兼容的接口转换成客户期望的样子就可以了。
但这不是说,在适配器里面就不需要实现功能。适配器里面可以实现功能,称这种适配器为智能适配器。再说了,在接口匹配和转换的过程中,也有可能需要额外实现一定的功能,才能转换过来,比如需要调整参数以进行匹配等。
## 举例
现在假设你缺少鸭子对象(叫声为Quack,飞行输出”I’m flying”),想用一些火鸡对象(叫声为”gobble” 飞行输出”I’m flying a short distance”)来冒充。显而易见,因为火鸡的接口(行为)不同,所以我们不能公然拿来使用。
URL设计:

## 代码实现
```cpp
#include <iostream>
#include <memory>
/**
* 定义鸭子类
*/
class Duck {
public:
virtual void quack() = 0; // 嘎嘎叫
virtual void fly() = 0;
virtual ~Duck() {}
};
/**
* 定义绿头鸭
*/
class MallardDuck : public Duck {
public:
void quack()
{
std::cout << "quack" << std::endl;
}
void fly()
{
std::cout << "I'm flying" << std::endl;
}
};
/**
* 定义火鸡
*/
class Turkey {
public:
virtual void gobble() = 0; // 咯咯叫
virtual void fly() = 0;
virtual ~Turkey() {}
};
/**
* 定义野火鸡
*/
class WildTurkey : public Turkey
{
public:
void gobble()
{
std::cout << "gobble" << std::endl;
}
void fly()
{
std::cout << "I'm flying a short distance" << std::endl;
}
};
/**
* 定义火鸡适配器, 适配Duck的接口
*/
class TurkeyAdapter : public Duck {
public:
TurkeyAdapter(Turkey* turkey) : turkey_(turkey) {}
void quack()
{
turkey_->gobble();
}
void fly()
{
turkey_->fly();
}
private:
Turkey* turkey_;
};
void test()
{
std::shared_ptr<Duck> duck_ptr(new MallardDuck());
duck_ptr->quack();
duck_ptr->fly();
std::shared_ptr<Turkey> wt_ptr(new WildTurkey());
std::shared_ptr<TurkeyAdapter> ta_ptr(new TurkeyAdapter(wt_ptr.get()));
ta_ptr->quack();
ta_ptr->fly();
}
int main()
{
test();
return 0;
}
```
输出结果:
```
quack
I'm flying
gobble
I'm flying a short distance
```
- 空白目录
- 算法
- 排序
- 冒泡排序
- 选择排序
- 插入排序
- 归并排序
- 快速排序
- 计数排序
- 桶排序
- 基数排序
- 希尔排序
- 堆排序
- 二分查找
- 最小堆
- 最小索引堆
- 平衡二叉树(AVL tree)
- bitmap位图
- 布隆过滤器
- hashmap
- topK
- 跳表
- LRU Cache
- kmp
- 最小堆和堆排序
- 最短路径
- C++
- 运行时类型判断RTTI
- C++反射
- 手动实现智能指针
- 序列化实现
- rpc实现
- std::forward
- 函数指针的妙用
- C/C++
- std::function
- 同步队列
- 线程池实现
- std::promise
- 深入理解虚函数
- extern "C" 关键字讲解
- 大端小端的区别
- 简历
- 简历1
- redis
- 数据结构和对象
- sds
- list
- zskiplist
- 腾讯云redis面试题总结
- redis集群部署
- LeetCode
- 目标
- go基础
- 算法快速入门
- 数据结构篇
- 二叉树
- 链表
- 栈和队列
- 二进制
- 基础算法篇
- 二分搜索
- 排序算法
- 动态规划
- 算法思维
- 递归思维
- 滑动窗口思想
- 二叉搜索树
- 回溯法
- 其他
- 剑指offer
- 笔记
- git代理加速
- Linux
- vim大法
- vscode远程不能跳转
- cmake
- 设计模式
- 单例模式
- 简单工厂模式
- 外观模式
- 适配器模式
- 工厂方法模式
- 抽象工厂模式
- 生成器模式
- 原型模式
- 中介者模式
- 观察者模式
- 访问者模式
- 命令模式
- 网络编程
- epoll reactor模式
- linux timerfd系列函数总结
- IO
- mapreduce
- 反射器
- leo通信库
- Mutex
- Condition
- thread
- raft
- 协程
- hook
- 定时器
- 别人的面试经验
- 面试题
- vector崩溃问题
- JAVA
- Linux java环境配置
- ucore
- lab1
- FreeNOS
- leveldb
- 刷题笔记
- 回文串
- 前缀树
- 字符串查找
- 查找两个字符串a,b中的最长公共子串
- 动态规划
- golang
- 顺序循环打印实现
- 数据结构
- rpc运用
- python
- 单例
- 深拷贝浅拷贝
- 链表
- python基础题
- mysql
- 事务
- Linux
- 共享内存
- 刷题记录
- 贪心算法
- 动态规划
- 面试
- 腾讯C++面试
- 微众面试JD
- 迅雷网络面试
- 学习网址
- rabbitMq
