加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

scala – 如何使用高阶函数来平坦化选项列表?

发布时间:2020-12-16 09:43:34 所属栏目:安全 来源:网络整理
导读:使用Scala 2.7.7: 如果我有一个选项列表,我可以使用理解来平坦化它们: val listOfOptions = List(None,Some("hi"),None)listOfOptions: List[Option[java.lang.String]] = List(None,Some(hi),None)scala for (opt - listOfOptions; string - opt) yield
使用Scala 2.7.7:

如果我有一个选项列表,我可以使用理解来平坦化它们:

val listOfOptions = List(None,Some("hi"),None)
listOfOptions: List[Option[java.lang.String]] = List(None,Some(hi),None)

scala> for (opt <- listOfOptions; string <- opt) yield string
res0: List[java.lang.String] = List(hi)

我不喜欢这种风格,宁愿使用HOF。这个尝试太冗长了,不能接受:

scala> listOfOptions.flatMap(opt => if (opt.isDefined) Some(opt.get) else None)
res1: List[java.lang.String] = List(hi)

直观地,我会期望以下的工作,但它不:

scala> List.flatten(listOfOptions)
<console>:6: error: type mismatch;
 found   : List[Option[java.lang.String]]
 required: List[List[?]]
       List.flatten(listOfOptions)

即使以下似乎应该是有效的,但不是:

scala> listOfOptions.flatMap(_: Option[String])
<console>:6: error: type mismatch;
 found   : Option[String]
 required: (Option[java.lang.String]) => Iterable[?]
       listOfOptions.flatMap(_: Option[String])
                          ^

我能想出的最好的是:

scala> listOfOptions.flatMap(_.toList)         
res2: List[java.lang.String] = List(hi)

…但我宁可不必将选项转换为列表。看起来很笨重

任何建议?

解决方法

在Scala 2.8中,flatten将会工作:

Welcome to Scala version 2.8.0.RC2 (Java HotSpot(TM) 64-Bit Server VM,Java 1.6.0_20).
Type in expressions to have them evaluated.
Type :help for more information.

scala> val listOfOptions = List(None,None)

scala> listOfOptions flatten
res0: List[java.lang.String] = List(hi)

但是,这在2.7.7中不起作用:

Welcome to Scala version 2.7.7.final (Java HotSpot(TM) 64-Bit Server VM,Java 1.6.0_20).

scala> val listOfOptions = List(None,None)

scala> listOfOptions.flatten
:6: error: no implicit argument matching parameter type (Option[java.lang.String]) => Iterable[Nothing] was found.
       listOfOptions.flatten

收藏库已经重新设计,并且在2.8中有了很大的改进,所以也许您可能想要尝试使用最新的Scala 2.8 RC,看看它是否更容易使用。

如果你真的不想使用toList方法,我猜你也可以这样写:

scala> listOfOptions.flatMap(o => o)
res: List[java.lang.String] = List(hi)

也许不是一件美丽的事情,但至少在2.7.7中有效。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读