【问题标题】:Using ComputeIfAbsent in HashMap在 HashMap 中使用 ComputeIfAbsent
【发布时间】:2018-09-12 15:16:39
【问题描述】:

我已经阅读过类似的帖子,但这是使用 computeIfAbsent 函数的正确方法吗? cookieMap 是一个 HashMap,response 是一个 Object,它包含所有的 headers、cookies、responses、status Code 等...

cookieMap.computeIfAbsent("Varlink", varLink -> {
  if (responses.getCookie("VARLINK").length() < 1) {
    throw new ProviderException("Varlink not present in response, check response status!!!");
  }
  return responses.getCookie("VARLINK");
});

我需要向 cookieMap 添加多个这样的键。我最初的想法是将所有内容都放在 If 条件中,但由于某些限制,我们不应该嵌套 if-else 条件(我猜 Code Reviewer 对 Clean Code 这本书太认真了)

【问题讨论】:

  • 很难说。 cookieMap 是什么? computeIfAbsent 用于检索映射中的值,并在提供的键不存在值时提供初始化机制。
  • 这是 HashMap
  • 它是如何使用的,它的意义/相关性是什么?为什么要使用 computeIfAbsent?是否有可能存在价值?
  • 假设cookieMaprespones是不同的map,这样使用没有问题,但是建议将respones.getCookie("VARLINK")的结果存入一个局部变量,而不是求值相同表达两次。此外,您可以考虑将 lambda 主体的代码移动到命名方法中(这将使大多数代码审阅者感到高兴)并在 computeIfAbsent 中使用方法引用或简单的 varLink -&gt; expression lambda 表达式。
  • @Holger 感谢您的回答。 responses 是一个对象,其中包含请求的所有 cookie、标头和响应。我最后做的是cookieMap.put("VARLINK", Preconditions.checkNotNull(respones.getCookie("VARLINK"), "Varlink not present in Response, check Response status!!!")); 原来response 对象返回一个null 如果密钥不存在。

标签: java java-8 hashmap


【解决方案1】:

如果responsescookieMap 是两个不同的数据源,那么你的sn-p 是正确的。唯一需要担心的是调用 cookieMap::getCookie 两次,这可能会像有人在 cmets 中建议的那样使用变量来解决。

我将使用Optional 将整个表达式缩短为:

cookieMap.computeIfAbsent("Varlink", v -> {
    Optional.of(respones.getCookie("VARLINK"))                // Gets a cookie
            .filter(c -> c.length() >= 1)                     // Filters the length
            .orElseThrow(() -> new ProviderException("...")); // Returns only if present
});

【讨论】:

  • 是的,responses 和 cookeMap 是两个不同的数据源。不过感谢您的方法,这很好。正如上面评论中提到的,对于我的实际代码,我使用了前提条件(番石榴)。
猜你喜欢
  • 2022-12-03
  • 1970-01-01
  • 1970-01-01
  • 2019-05-28
  • 2013-10-17
  • 2021-12-09
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多