Loading

Go 中 defer 和 return 执行的先后顺序

  1. 多个defer的执行顺序为“后进先出”;

  2. defer、return、返回值三者的执行逻辑应该是:

    (1) return最先执行,return负责将结果写入返回值中;

    (2) 接着defer开始执行一些收尾工作;

    (3) 最后函数携带当前返回值退出。

1. 不带命名返回值的函数

如果函数的返回值是无名的(不带命名返回值),则 go 语言会在执行 return 的时候会执行一个类似创建一个临时变量作为保存 return 值的动作,所以执行 defer 的时候将不会影响到最后 return 的值。

package main
 
import "fmt"
 
func main() {
    fmt.Println("return:", test())
}

func test() int {  //这里返回值没有命名
    var i int
    defer func() {
        i++
        fmt.Println("defer1", i)
    }()
    defer func() {
        i++
        fmt.Println("defer2", i)
    }()
    return i
}

输出结果为:

defer2 1
defer1 2
return: 0

2. 带命名返回值的函数

而有名返回值的函数,由于返回值在函数定义的时候已经将该变量进行定义,在执行 return 的时候会先执行返回值保存操作,所以执行 defer 操作后对该变量的修改会影响到 return 的值。

package main

import "fmt"

func main() {
    fmt.Println("return:", test())
}

func test() (i int) { //返回值命名i
    defer func() {
        i++
        fmt.Println("defer1", i)
    }()
    defer func() {
        i++
        fmt.Println("defer2", i)
    }()
    return i
}

输出结果为:

defer2 1
defer1 2
return: 2
posted @ 2022-02-13 10:52  拾月凄辰  阅读(622)  评论(0编辑  收藏  举报