要做的事情就是遍历一个map,做一些判断,如果符合一定条件,就删除。
代码尽量简洁高效(感谢付老板指点):关键点就是要知道map的erase不会令iterator失效,之前不确定的时候做了很多额外的工作保证其正确性。
for (map<key, value>::iterator it = testMap.begin(); it!=testMap.end(); ) { if(it->second->Recyclable()) { testMap.erase(it++); } else { ++it; } }
本文探讨了在遍历Map并删除符合条件项时的优化策略,重点在于理解Map的erase方法对迭代器的影响,以及如何避免不必要的迭代器失效检查。
2万+

被折叠的 条评论
为什么被折叠?



