4

我有一个哈希映射的双嵌套哈希映射,并且想要检查键是否存在并放置新值。目前我正在嵌套 if 语句以检查每个级别的键是否存在。有没有更有效的编码方式?

HashMap<Foo1, HashMap<Foo2, HashMap<Foo3, Double>>> my_map = new HashMap<Foo1, HashMap<Foo2, HashMap<Foo3, Double>>>();

if (my_map.containsKey(foo1key)) {

    if (my_map.get(foo1key).containsKey(foo2key)) {

        if (my_map.get(foo1key).get(foo2key).containsKey(foo3key)) {

             return my_map.get(foo1key).get(foo2key).get(foo3key);
        }
    }
}

double foo3key = getValue();

// do the above steps again to put foo3key into map.
4

1 回答 1

1

最有效的方法(假设您的值始终为非空)如下:

HashMap<Foo2, HashMap<Foo3, Double>> map2 = my_map.get(foo1Key);
if(map2!=null) {
  HashMap<Foo3, Double> map3 = map2.get(foo2Key);
  if (map3!=null) {
    Double value = map3.get(foo3Key);
    if (value!=null) {
      return (double)value;
    } else {
      // add value to map3, or whatever
    }
  }
}

这利用了以下技术:

  • 如果get()返回null,就知道key不存在(因为不允许null值)
  • 保存上一次get的返回值,方便下次查找,这样就不需要把gets链在一起了

不过,这有点混乱-如果您经常进行这种操作,那么我建议您将其分解为一个单独的函数,这样您就可以这样做:

double value = getNestedValue(my_map,foo1Key,foo2Key,foo3Key);
于 2012-05-24T00:31:14.103 回答