Gur*_*een 2 scala scala-collections
在阅读有关Scala的书时,我偶然发现了以下代码.无法将代码分离为函数,参数,变量.
val feeds = Map("Andy Hunt" -> "blog.toolshed.com",
"Dave Thomas" -> "pragdave.me",
"NFJS" -> "nofluffjuststuff.com/blog")
val fiterName = feeds filter { element =>
val (key, value) = element
(key startsWith "D") && (value contains "pragprog")
}
Run Code Online (Sandbox Code Playgroud)
有人可以一步一步解释我的代码吗?
feeds是一个Map[String, String]将人映射到博客的.
然后该映射与a迭代filter,它试图过滤任何以大写字母开头D并且其值包含单词"pragprog"的作者.
当你filter在a上时Map,你会得到一个元组,它将键作为第一个元素,值作为第二个元素.使用圆括号,它看起来像这样:
val filterName = feeds.filter(element => {
val (key, value) = element
key.startsWith("D") && value.contains("pragprog")
})
Run Code Online (Sandbox Code Playgroud)
请注意,过滤器本身是一个更高阶的函数,它需要另一个函数作为输入.这个函数接受一个类型的参数A,在我们的例子中是一个元组(String, String),并产生一个布尔值,指示元素是否与条件匹配.在过滤器内部,他们使用元组解构:
val (key, value) = element
Run Code Online (Sandbox Code Playgroud)
它接受Tuple2[String, String]并调用它的unapply方法,允许您按名称访问元组的组件,而不是通过._1和_.2