前言
容器是什么想必大家和我一样都清楚了,无非就是封装好的类模板。在类的基础之上,又大大扩充了C++的性能。那么适配器是什么,在C++体系中又扮演一个什么样的角色呢?今晚揭晓这个问题。
“适配器”是个啥
适配器的本质是使一种事物的行为类似于另一种事物的行为的一种机制。我目前的理解就是一种“再封装”,至于用什么技术实现则看具体什么类型的适配器了。一般来说适配器支持的操作会比较少,不支持迭代器和算法,使用的限制比较大。
具体怎么用?
下面以一个简单的Stack适配器测试程序讲解,主要看注释部分:
容器是什么想必大家和我一样都清楚了,无非就是封装好的类模板。在类的基础之上,又大大扩充了C++的性能。那么适配器是什么,在C++体系中又扮演一个什么样的角色呢?今晚揭晓这个问题。
“适配器”是个啥
适配器的本质是使一种事物的行为类似于另一种事物的行为的一种机制。我目前的理解就是一种“再封装”,至于用什么技术实现则看具体什么类型的适配器了。一般来说适配器支持的操作会比较少,不支持迭代器和算法,使用的限制比较大。
具体怎么用?
下面以一个简单的Stack适配器测试程序讲解,主要看注释部分:
/*
* 程序功能:先建立一个Vector容器(元素为整型1-10);然后用这个容器初始化一个Stack适配器;
* 最后将这个栈自顶到底输出。
*/
#include <iostream>
#include <string>
#include <vector>
#include <stack>
using namespace std;
const int MAX=10;
int main()
{
vector<int> v;
/*
* 建立测试容器,存放1-10整数。
*/
for(int i=0; i<MAX; i++) {
v.push_back(i+1);
}
/*
* 输出测试容器。
*/
for (vector<int>::iterator it=v.begin(); it!=v.end(); it++) {
cout << *it << endl;
}
/*
* 以测试容器v为参数,构造测试容器适配器s。
*/
stack< int, vector<int> > s(v);
/*
* 自顶向底输出所有容器元素。
*/
while (!s.empty()) {
cout << s.top() << endl;
s.pop();
}
return 0;
}