分享
golang逃逸(escape)的问题
王艳秋1 · · 1673 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
在C语言中,使用malloc函数分配生成的变量都在堆上面,其他的普通变量都在栈上面。使用C++语言,使用new生成的对象都在堆上面,其他的普通变量都在栈上面。
golang情况不是这样的,golang的编译器会自动分析代码,如果一个在函数内分配的变量会返回到函数外面,那么这个变量会在堆上分配,而不是在栈上面。
这样就不会出现空指针的问题。但是堆存在垃圾回收的问题,垃圾回收需要占用比较多的性能。所以尽量避免使用堆上的空间,尽量使用栈上的空间。故而在函数中,参数优先使用普通变量,而不是指针变量。
go build -gcflags. "-m -l" test.go
-m的含义就是打印变量逃逸的case
func foo() *int {
t :=8
return &t;
}
func main() {
x :=foo()
fmt.Println(*x)
y:=foo1()
fmt.Println(*y)
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1673 次点击
上一篇:golang的一些点
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
在C语言中,使用malloc函数分配生成的变量都在堆上面,其他的普通变量都在栈上面。使用C++语言,使用new生成的对象都在堆上面,其他的普通变量都在栈上面。
golang情况不是这样的,golang的编译器会自动分析代码,如果一个在函数内分配的变量会返回到函数外面,那么这个变量会在堆上分配,而不是在栈上面。
这样就不会出现空指针的问题。但是堆存在垃圾回收的问题,垃圾回收需要占用比较多的性能。所以尽量避免使用堆上的空间,尽量使用栈上的空间。故而在函数中,参数优先使用普通变量,而不是指针变量。
go build -gcflags. "-m -l" test.go
-m的含义就是打印变量逃逸的case
func foo() *int {
t :=8
return &t;
}
func main() {
x :=foo()
fmt.Println(*x)
y:=foo1()
fmt.Println(*y)