golang的闭包和普通函数调用区别

liangDream · · 7577 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

先看一段程序

 

 

package main


import (
  "fmt"
)

 func main() {
   a := []int{1, 2, 3}
   for _, i := range a {
     fmt.Println(i)
     defer p(i)
   }
 }
 
 func p(i int) {
  fmt.Println(i)
 }

运行这段程序,输出结果为

1

2

3

3

2

1

这里就是普通的函数调用,每次调用func p时,完成 i 的值复制,然后打印,此时 i 值复制了3次,分别是1,2,3。由于defer是后进先出,所以执行变成3,2,1

下面我我们用闭包改写下程序:

package main

import (
  "fmt"
)

func main() {
  a := []int{1, 2, 3}
  for _, i := range a {
    fmt.Println(i)
    defer func() {
       fmt.Println(i)
    }()
    }
}

运行这段程序,输出结果为

1

2

3

3

3

3

这个就是闭包的“神奇”之处。闭包里的非传递参数外部变量值是传引用的,在闭包函数里那个i就是外部非闭包函数自己的参数,所以是相当于引用了外部的变量, i 的值执行到第三次是3 ,闭包是地址引用所以打印了3次i地址指向的值,所以是3,3,3

本文来自:博客园

感谢作者:liangDream

查看原文:golang的闭包和普通函数调用区别

7577 次点击  ∙  1 赞  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传