>?,c++,stack"/>

首页 > 解决方案 > 如何迭代一堆地图:std::stack< std::map>?

问题描述

我有一个遍历地图堆栈的 for 循环,但是当我执行代码时出现分段错误。我的代码是这样的:

// std::stack< std::map<string, string> > STACK;
size_t getStackSize() { return this->STACK.size();}
std::stack< std::map<string, string> > getSTACK() { return this->STACK;}
for (size_t i = 0; i < ObjSTACK.getStackSize(); ++i )
{
    for (auto& [v, l] : ObjSTACK.getSTACK().top())
    {
        std::cout << v << ':' << l << '\n';
    }    
    ObjSTACK.getSTACK().pop();
}

为什么我得到分段错误?有没有更好的方法来迭代 std::stack< std::map<string, string>> ?

标签: c++stack

解决方案


getStack()每次调用它时都返回一个副本,因此std::stack

while (!ObjSTACK.getSTACK().empty())

充其量是非常低效的,但是

ObjSTACK.getSTACK().pop();

将是无操作的,因为您是从 temp 弹出的std::stack,而不是原始的。因此getStackSize()不会改变值,并且外循环将永远运行。

改为getStack()返回一个引用,以便循环可以实际修改std::stack

std::stack< std::map<string, string> >& getSTACK() { return this->STACK; }

推荐阅读