C&C++   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了c – 将值分配给unordered_map的基本问题大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个unordered_map存储int作为键作为一个指针作为值.我需要检查键的存在.如果密钥不可用,我需要插入密钥和值.哪一个是更好的方法

谢谢.

unordered_map<int,classA*>testMap;
classA* ptr = testMap[1];
if(ptr == NULL)
   testMap[1] = new classA;


OR

unordered_map<int,classA*>::iterator it = testMap.find(1);
if(it == testMap.end())
{
  testMap.insert(make_pair(1,new classA));
}

解决方法

这两种方法都不好,因为两者都可以在地图中使用两个查询.

更好的方法是检索对元素的引用,如果该引用是空指针,则分配给它:

classA*& ptr = testMap[1];
if (ptr == 0)
    ptr = new classA;

这是因为查询地图中不存在的元素会自动插入(认构造,因此将插入空指针),而operator []返回对该元素的引用(无论是新创建还是已存在).

但请注意,此方法(或您的第一种方法)和第二种方法间的语义巧妙地不同:如果键不存在于地图中,则第二种方法仅插入该元素.我的方法(和你的第一个方法)也创建一个新的元素,如果键实际上已经存在,但它的值是一个空指针.

大佬总结

以上是大佬教程为你收集整理的c – 将值分配给unordered_map的基本问题全部内容,希望文章能够帮你解决c – 将值分配给unordered_map的基本问题所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: