![](/img/trans.png)
[英]how to traverse in a unordered_map of unordered_map of unordered_map in c++
[英]How to clear unordered_map of unordered_map in c++?
我有一张地图如下图所示。
struct B {
int b1;
int b2;
int b3;
};
struct A {
B a1;
B a2;
};
unordered_map<int, unordered_map<int, A>> outer_map;
我用一些元素填充了这个inner_map,每个内部map对象也初始化了几个元素。
所以我的问题是如何清除outer_map,以便我可以新填充数据?
outer_map.clear()有效吗? 当你在这里打电话时,内部到底发生了什么? 有人可以提供一些内部细节吗?
如果运行outer_map.clear()
, outer_map.clear()
键( int
)和值( unordered_map<int, A>
)。 当它们被移除时,如果有任何析构函数要调用,它们将被调用。 这意味着将调用任何存储的unordered_map<int, A>
的析构函数,这反过来将删除所有的A
,也调用它们的析构函数。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.