在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
defer用于延迟执行,可以类比于java或c++中的析构函数。
查看一段示例代码: func Contents(filename string) (string, error) { //打开文件 f, err := os.Open(filename) if err != nil { return "", err } //使用延期调用,由于defer的作用,在Contents函数执行结束完成后才会关闭文件,紧跟着open,可以防止忘掉关闭,且代码结构更清晰 defer f.Close() //f.Closewillrunwhenwe'refinished. var result []byte buf := make([]byte, 100) for { n, err := f.Read(buf[0:]) result = append(result, buf[0:n]...) // append is discussed later. if err != nil { if err == io.EOF { break } return "", err //如果这时候返回,f.Close()随后会被掉用 } return string(result), nil // //如果这时候返回,f.Close()随后会被掉用 }
使用defer需要记住两点 1、先进后出的顺序 2、函数参数会在使用defer调用时就被求值。
例2: defer fmt.Print("a ") defer fmt.Print("b ") 输出结果为:b a 因为后进先出,就像用砖砌墙一样,后来者居上。
例3: i := 0 defer fmt.Printf("%d ", i) i = 10 defer fmt.Printf("%d ", i)
输出结果: 10 0 执行第一个defer时,使用的值是0,而不是函数最后执行结束时变成的10。 |
请发表评论