前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++ 23种设计模式(6)-适配器模式

C++ 23种设计模式(6)-适配器模式

作者头像
全栈程序员站长
发布2022-09-15 09:51:43
3730
发布2022-09-15 09:51:43
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

适配器模式将一个类的接口转换成客户希望的另外一个接口,使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。它包括类适配器和对象适配器,本文针对的是对象适配器。举个例子,在STL中就用到了适配器模式。STL实现了一种数据结构,称为双端队列(deque),支持前后两段的插入与删除。STL实现栈和队列时,没有从头开始定义它们,而是直接使用双端队列实现的。这里双端队列就扮演了适配器的角色。队列用到了它的后端插入,前端删除。而栈用到了它的后端插入,后端删除。假设栈和队列都是一种顺序容器,有两种操作:压入和弹出。 代码如下:

代码语言:javascript
复制
#include<iostream>
#include<string>
using namespace std;

//双端队列
class Deque
{ 
   
public:
	void push_back(int x) { 
    cout << "Deque push_back" << endl; }
	void push_front(int x) { 
    cout << "Deque push_front" << endl; }
	void pop_back() { 
    cout << "Deque pop_back" << endl; }
	void pop_front() { 
    cout << "Deque pop_front" << endl; }
};
//顺序容器
class Sequence
{ 
   
public:
	virtual void push(int x) = 0;
	virtual void pop() = 0;
};
//栈的父类是顺序容器 用到的方法是双端队列
class Stack : public Sequence
{ 
   
public:
	void push(int x) { 
    deque.push_back(x); }
	void pop() { 
    deque.pop_back(); }
private:
	Deque deque; //双端队列
};
//队列的父类是顺序容器 用到的方法是双端队列
class Queue : public Sequence
{ 
   
public:
	void push(int x) { 
    deque.push_back(x); }
	void pop() { 
    deque.pop_front(); }
private:
	Deque deque; //双端队列
};

int main()
{ 
   
	Sequence *s1 = new Stack();
	Sequence *s2 = new Queue();
	s1->push(1); s1->pop();
	s2->push(1); s2->pop();
	delete s1; delete s2;
	getchar();
	return 0;
}

执行结果如下:

在这里插入图片描述
在这里插入图片描述

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/160038.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档