我正在使用stl堆栈和队列来存储大量项目。如何在内部实现标准模板库中的堆栈?它是链表的形式吗?或者是否有任何最大尺寸?
答案 0 :(得分:7)
C ++标准库中的堆栈和队列都是容器适配器。这意味着他们使用指定的容器作为存储数据的基础手段。默认情况下,它们都使用std::deque
,但您可以使用例如矢量
std::stack<int,std::vector<int>> s;
答案 1 :(得分:-3)
vector works internally...
#include <iostream>
#include <vector>
struct Sample
{
Sample(){}
Sample(const Sample & obj)
{
std::cout<<"Sample copy constructor"<<std::endl;
}
};
int main()
{
std::vector<Sample> vecOfInts;
std::cout<<"Capacity :: "<<vecOfInts.capacity()<<std::endl;
std::cout<<"Size :: "<<vecOfInts.size()<<std::endl;
int capcity = vecOfInts.capacity();
for(int i = 0; i < capcity + 1; i++)
vecOfInts.push_back(Sample());
std::cout<<"Capacity :: "<<vecOfInts.capacity()<<std::endl;
std::cout<<"Size :: "<<vecOfInts.size()<<std::endl;
for(int i = 0; i < capcity + 1; i++)
vecOfInts.push_back(Sample());
std::cout<<"Capacity :: "<<vecOfInts.capacity()<<std::endl;
std::cout<<"Size :: "<<vecOfInts.size()<<std::endl;
return 0;
}