登录
首页 >  Golang >  Go问答

闭包在内存中是如何存储的?

来源:stackoverflow

时间:2024-03-24 10:15:47 174浏览 收藏

Go 闭包在内存中作为堆分配存储,其中幸存的变量被放置在堆上。在函数调用中返回的 func() 值的大小取决于闭包引用的变量大小。闭包的布局包括一个指向函数代码的指针和指向闭包变量的指针。

问题内容

有关闭包的一般说明,请参阅 javascript 闭包如何工作?

go 闭包到底是如何在内存中布局的?

以以下函数为例:

type M int

func (m *M) Adder(amount int) func() {
    return func() {
        *m = *m + amount
    }
}

当我们的代码调用 a := m.adder() 时,堆上分配了多少内存以及它是什么样的?返回的 func() 值占用多少内存(无论它最终位于内存中的哪个位置)?


解决方案


The Go Programming Language Specification

Function literals

函数文字代表匿名函数。

functionlit = "func" 签名函数体.

func(a, b int, z float64) bool { return a*b < int(z) }

函数文字可以分配给变量或直接调用。

f := func(x, y int) int { return x + y }
func(ch chan int) { ch <- ack }(replychan)

函数文字是闭包:它们可以引用定义在 周围的函数。然后这些变量在 围绕函数和函数文字,它们作为 只要它们可以访问。

闭包可以引用定义在 周围的函数。然后这些变量在 围绕函数和函数文字,它们作为 只要它们可以访问。

在函数调用中幸存下来的变量被放置在堆上。在 go 中,闭包确实就是这么简单。

例如,

func closure() func() *byte {
    var b [4 * 1024]byte
    return func() *byte {
        return &b[0]
    }
}

closure() 调用是两次堆分配,一次分配 16(在 amd64 上 = 8 + 8)字节

struct { f uintptr; b *[4096]byte }

还有一个 4096 字节

[4096]byte

总共 4112 字节。

这篇博文回答了当前版本的 go 编译器的问题:

https://philpearl.github.io/post/functionpointers/

理论要掌握,实操不能落!以上关于《闭包在内存中是如何存储的?》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>