为什么在Golang中的闭包体后添加“()”?

前端之家收集整理的这篇文章主要介绍了为什么在Golang中的闭包体后添加“()”?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在阅读的Go编程语言规范,发现我自己不真正理解与闭包体后面的“()”:

函数文字

func(ch chan int) { ch <- ACK }(replyChan)`

在Defer语句的示例中:

// f returns 1
func f() (result int) {
    defer func() {
        result++
    }() // why and how?
    return 0
}

我不清楚添加&使用“()”后封闭体,希望有人能够清楚地解释这一点。

它不是()必须添加后(只)一个闭包在延迟。语言规定 defer statement的任务,它的“表达式”总是必须是一个函数调用

为什么会这样?它与任何其他函数相同,在’defer’或不:

考虑:

func f() int { return 42 }

a := f

vs

b := f()

第一个表达式RHS是一个函数值。在第二个版本中,RHS是函数返回的值 – 即函数调用

因此,语义是:

defer f

vs

defer f()

除了第一个版本在’defer’的上下文中没有意义,因此规范提到它必须是第二个形式(仅)。

它的IMHO也更容易学习,因为与’defer’语句之外的上述讨论的函数调用的正交性。

还要注意的是,函数调用不仅是fn-expr后跟(),而且表达式列表通常在括号内(包括空列表)。有很大的区别:

for i := range whatever {
        defer func() { fmt. Println(i) }()
}

for i := range whatever {
        defer func(n int) { fmt. Println(n) }(i)
}

第一个版本在执行闭包时打印’i’的值,第二个版本在执行defer语句时打印’i’的值。

猜你在找的Go相关文章