c++ 为什么 stack 是用队列实现的

 我来答
帐号已注销
2016-10-29 · TA获得超过3954个赞
知道大有可为答主
回答量:1636
采纳率:77%
帮助的人:1227万
展开全部

std::stack的设计意图是作为一个容器适配器,而不是真正意义上的栈容器。


这样做可以在一定程度上将你的代码(用户代码)与实现细节隔离。你可以在不影响大部分的std::stack用户代码的情况下改变std::stack内部具体的存储结构。


#include <stack>
#include <list>

template <typename R>
void UseStack( std::stack<int, R> & stack ) { 
    stack.push( 1 ); 
    stack.push( 2 ); 
    stack.push( 3 );
}

int main() { 
    std::stack<int, std::deque<int>> stack1; 
    UseStack( stack1 ); 
    std::stack<int, std::list<int>> stack2; 
    UseStack( stack2 );
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式