
为什么 go 中 defer 函数打印结果与预期不同?
在 go 中使用 defer 延迟执行函数时,可能会遇到打印结果与预期不同的情况。本文将解释一个常见的案例。
问题:
下方的 go 代码将打印什么结果?
package main
import "fmt"
func main() {
a := 1
defer func() { fmt.println(a) }()
defer func(a int) { fmt.println(a) }(a)
defer fmt.println(a)
a++
}答案:
打印结果是:
2 1 2
解释:
defer 遵循后进先出(lifo)原则,这意味着最后注册的函数将最先执行。对于上面的代码:
- a++:将 a 的值增加到 2。
-
执行 defer 函数:
- 第三个 defer 调用了无参函数,它将在 main 函数返回时打印 a 的当前值(2)。
- 第二个 defer 调用了带参函数,该函数接受 a 参数。当函数执行时,它将打印它在注册时保存的 a 值(1)。
- 第一个 defer 调用了无参函数,它将在 main 函数返回时打印 a 的当前值(2)。
因此,最终打印的结果是 2、1 和 2。
还需要注意,在注册 defer 函数时,该函数的参数必须已确定其值。在上面的代码中,第二个 defer 函数的 a 参数在注册时被赋值为 1。当函数执行时,它仍将打印 1,即使 a 的值已在 main 函数中增加。











