Lambda

badge

匿名函数是一种无需命名即可动态创建函数对象的语法

# `->` 是匿名函数操作符
# 同 `f x, y = x + y`
f = (x, y) -> x + y
# same as `g(x, y: Int): Int = x + y`
g = (x, y: Int): Int -> x + y

如果只有一个参数,您可以省略 ()

assert [1, 2, 3].map_collect(i -> i + 1) == [2, 3, 4]
assert ((i, j) -> [i, j])(1, 2) == [1, 2]

在下面的情况下,它是 0..9, (i -> ...) 而不是 (0..9, i) -> ... -> 在左侧只接受一个参数。多个参数作为单个元组接收

for 0..9, i: Int ->
    ...

在匿名函数中,由于空格,解析存在差异

# 在这种情况下,解释为 `T(() -> Int)`
i: T() -> Int
# 在这种情况下,它被解释为 (U()) -> Int
k: U() -> Int

匿名函数可以不带参数使用

# `=>` 是一个匿名过程操作符
p! = () => print! # `p!` 被调用
# `() ->`, `() =>` 有语法糖 `do`, `do!`
# p! = do! print! "`p!` 被调用
p!() # `p!` 被调用

无参数函数可用于延迟初始化

time = import "time"
date = import "datetime"
now = if! True:
    do!:
        time. sleep! 1000
        date.now!()
    do date.new("1970", "1", "1", "00", "00")

您还可以键入和模式匹配。正因为如此,match 函数大多是借助匿名函数的力量来实现的 作为 match 函数的参数给出的匿名函数从顶部开始按顺序尝试。因此,您应该在顶部描述特殊情况,在底部描述更一般的情况。如果你弄错了顺序,编译器会发出警告(如果可能的话)

n = (Complex or Ratio or Int).sample!()
i = matchn:
    PI -> PI # 如果等于常数 PI
    For (i: 1..10) -> i # 整数从 1 到 10
    (i: Int) -> i # Int
    (c: Complex) -> c.real() # 对于复杂。Int < Complex,但可以回退
    _ -> panic "cannot convert to Int" # 如果以上都不适用。match 必须涵盖所有模式

错误处理通常也使用 ?match 完成

res: ParseResult Int
matchres:
    i: Int -> i
    err: Error -> panic err.msg

res2: Result Int, Error
match res2:
    ok: Not Error -> log Type of ok
    err: Error -> panic err.msg

匿名多相关系数

# 与此相同 id|T|x: T = x
id = |T| x: T -> x