让我们了解 Golang 如何处理变量以及逃逸分析是什么。 Golang 有两种在 Go 运行时环境中使用的内存分配数据类型,称为堆栈和堆。
堆栈执行(输入和输出)操作的速度更快。函数内访问的变量会进入该堆栈。 例如:
这就是堆栈在 GoLang 中的工作原理。接下来是一堆。它是一个动态存储器,即它的大小可以根据需要进行调整。这是堆分配的简单示例。
这里由于函数返回一个指向 num 的指针,Go 运行时检测到 num 将在函数作用域之外被访问。结果,它在堆上而不是堆栈上分配 num。
堆用于存储超出函数或 Goroutine 范围的变量。有时,当变量的值非常大时,它会存储在堆中。
理解了这两个之后,就可以进入逃逸分析了。仅通过阅读 Go 代码无法知道哪些变量将被分配到堆中。我们可以通过“逃逸分析”来理解这一点。所谓转义,是指变量是否转义了函数的作用域,决定了它是存储在堆还是栈上。
像这样运行go代码的构建命令
-m - 显示逃逸分析的标志。
-l - 禁用内联以保持堆栈跟踪准确。
获取此代码:
结果如下:
那么,我们为什么要做这些呢?当您调试性能问题时,此分析非常有用。变量最好存储在堆栈中而不是堆中。您可以找到变量逃逸到堆的位置并重构代码以提高效率。
希望你今天学到了新东西。
我目前正在构建 LiveAPI,这是一个用于 API 文档生成的工具,请尝试一下。
感谢您的阅读。
以上是GoLang 超越基础:逃逸分析的详细内容。更多信息请关注PHP中文网其他相关文章!