下标

badge

[] 不同于普通的方法

a = [!1, !2]
a[0].inc!()
assert a == [2, 2]

回想一下,子例程的返回值不能是引用 这里的 a[0] 的类型显然应该是 Ref!(Int!)(a[0] 的类型取决于上下文) 所以 [] 实际上是特殊语法的一部分,就像 . 一样。与 Python 不同,它不能被重载 也无法在方法中重现 [] 的行为

C = Class {i = Int!}
C.steal(self) =
    self::i
C. get(ref self) =
    self::i # 类型错误:`self::i`是`Int!`(需要所有权)但`get`不拥有`self`
# OK (分配)
c = C.new({i = 1})
i = c.steal()
i.inc!()
assert i == 2
# or (own_do!)
own_do! C.new({i = 1}).steal(), i => i.inc!()
# NG
C.new({i = 1}).steal().inc!() # OwnershipWarning: `C.new({i = 1}).steal()` is not owned by anyone
# hint: assign to a variable or use `uwn_do!`

此外,[] 可以不承认,但元素不会移动

a = [!1, !2]
i = a[0]
i.inc!()
assert a[1] == 2
a[0] # 所有权错误:`a[0]`被移动到`i`