这并不是说
()必须(仅)一个后添加 封
在
defer。defer语句的语言规范要求其“
expression” 始终 必须是函数调用。
为什么会这样呢?不管是否“推迟”,它与任何其他功能相同:
考虑:
func f() int { return 42 }和
a := f
与
b := f()
第一表达式RHS是函数值。在第二个版本中,RHS是函数 返回 的值-即函数调用。
的语义也是如此:
defer f
与
defer f()
除了在“ defer”的上下文中第一个版本没有意义外,因此规范中提到它必须是第二种形式(仅)。
由于与上面讨论的’defer’语句之外的函数调用具有正交性,因此IMHO也更容易学习。
还要注意,函数调用不仅是fn-expr后跟
(),而且表达式列表通常在括号内(包括一个空列表)。之间有很大的区别:
for i := range whatever { defer func() { fmt. Println(i) }()}和
for i := range whatever { defer func(n int) { fmt. Println(n) }(i)}关闭时,第一个版本在当下打印的“我”的值 执行 ,第二打印“我”在当下的价值时,defer语句 被 执行。



