在阅读有关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") }
有人可以一步一步解释我的代码吗?
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") })
请注意,过滤器本身是一个更高阶的函数,它需要另一个函数作为输入.这个函数接受一个类型的参数A
,在我们的例子中是一个元组(String, String)
,并产生一个布尔值,指示元素是否与条件匹配.在过滤器内部,他们使用元组解构:
val (key, value) = element
它接受Tuple2[String, String]
并调用它的unapply
方法,允许您按名称访问元组的组件,而不是通过._1
和_.2