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

Scala并行分配仅在声明中

发布时间:2020-12-16 09:57:11 所属栏目:安全 来源:网络整理
导读:有: def f () = { (1,"two",3.0)} 为什么没事 var (x,y,z) = f() 但不是 var i = 0var j = "hello"var k = 0.0// use i,j,k...//then(i,k) = f() // ; expected but = found ? 解决方法 在初始化变量时,您会看到模式匹配的限制版本.请注意,这不仅适用于元
有:

def f () = {
    (1,"two",3.0)
}

为什么没事

var (x,y,z) = f()

但不是


var i = 0
var j = "hello"
var k = 0.0

// use i,j,k
...
//then
(i,k) = f() // ; expected but = found

解决方法

在初始化变量时,您会看到模式匹配的限制版本.请注意,这不仅适用于元组:

val a :: b = List(1,2,3)
println(a) //1
println(b) //List(2,3)

这个功能似乎是直接从Haskell借用的,在那里你也可以使用模式进行初始化:

let (a,b) = getTuple 
in a*b

由于Haskell没有可变数据,因此无法分配任何内容.

在Scala你可以做这样的事情,但我想这被认为太混乱,或者可能太难实现.您可以像往常一样使用匹配表达式,通常只需要一个案例,例如列表((1,2),(3,4)).map {case(a,b)=> a * b}.

(编辑:李大同)

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

    推荐文章
      热点阅读