繁体   English   中英

将 unordered_map 设置为 unordered_map 的值

[英]Setting unordered_map as value for unordered_map

所以我试图将 unordered_map 设置为另一个 unordered_map 的值。 现在我遇到了无法将值放入第二个 unordered_map 的问题。 我的代码看起来像这样。

  std::string postCode;
  std::string[] postCodeSource = new std::string{1111,2222,3333,4444};
  std::unordered_map<std::string,unordered_map<int,Foo*>*> data;
  int k1=1234;//can be any number
  for(int i = 0; i < 4; i++){
    postCode = postCodeSource[i]
    if(data[postCode]==NULL) {
      data[postCode]=new std::unordered_map<int,Foo*>();
    }
    data[postCode]->at(int(k1)) = new Foo(postCodeSource[i]);
  }

类:

class Foo{
  public:
  Foo();
  Foo(std::string postCode);
  std::string firstName,Customername,postCode;
}

Foo(std::string postCode); 是一个简单的复制构造函数。

现在当我到达data[lastPlz.getString()]->at(int(k1.customer)) = new Foo(&k1); 我从 unordered_map 得到了一个超出范围的例外,这是有道理的,因为 k1.customer 上还没有对象! 在我更改代码之前,我创建并填充了一个看起来像这样的指针。

std::unordered_map<int,Foo*> kdnrMap
kdnrMap[k1.customer] = new Foo(&k1);

后来,我将kdnrMap添加到data 这将不再像我想要的那样工作,因为这个方法需要一个完全填充的kdnrMap才能将它添加到我不能再做的数据中。

所以我正在寻求帮助来填充kdnrMap我已经尝试了几乎所有我现在能想到的东西。

您实际上并不需要将内部映射存储为指针。 就像这样让外部地图拥有内部地图:

std::unordered_map<std::string,
   std::unordered_map<int, std::unique_ptr<Foo>>> data;
data[postCode][int(k1.Kundennr)] = new Foo(&k1);

我建议不要在此处使用原始指针,因为如果替换内部映射中的值,则存在泄漏内存的高风险。 使用std::unique_ptr使得处理指针变得如此简单。

您的异常可能发生,因为unordered_map::at要求值包含您要求的键,以便检索对其映射的值的引用。 如果您像在我的示例中那样使用operator[] ,则如果未找到键,地图将创建一个条目。

如果您仍然坚持将外部映射的值作为指向内部映射的指针,那么您可以添加如下元素:

std::unordered_map<int, Foo*> &inner = *data[postCode];
inner[int(k1.Kundennr)] = new Foo(&k1);

或者

data[postCode]->operator[](int(k1.Kundennr)) = new Foo(&k1);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM