内容简介:根据可以使用编译参数我们可以通过添加
根据 Proposal: Mid-stack inlining in the Go compiler
,当前 go1.9+
已经支持用户调整编译器的内联程度。
可以使用编译参数 go build -gcflags="-l=4"
增加内联程度,从而提升9%的运行速度,代价是生成的二进制程序大小提升11-15%,看起来是很不错的一个交换。
我们可以通过添加 -m=2
参数来对比效果。我们可以使用下列命令来对比前后内联的程度,数据结果越少,表示内联的函数越多。
# 优化前 go build -gcflags="-m=2" 2>&1 | grep "too complex" # 优化后 go build -gcflags="-m=2 -l=4" 2>&1 | grep "too complex"
根据 cmd/compile/internal/gc/inl.go
源码显示, -l
的取值为:
// The debug['l'] flag controls the aggressiveness. Note that main() swaps level 0 and 1, // making 1 the default and -l disable. Additional levels (beyond -l) may be buggy and // are not supported. // 0: disabled // 1: 80-nodes leaf functions, oneliners, panic, lazy typechecking (default) // 2: (unassigned) // 3: (unassigned) // 4: allow non-leaf functions
当然,一味的吹求函数内联并不总能带来性能的提高,因为随着代码段大小的提升,CPU运行时 instruction cache miss
会随之增加,过高时会 适得其反
,所以是否采用还要以实际的PROFILE为准绳。
以上所述就是小编给大家介绍的《提升go编译器内联程度》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 内联函数和编译器对 Go 代码的优化
- iframe内联框架之巧妙跨域
- 智能合约基础语言(十):Solidity内联汇编
- 重学前端:块级元素与内联元素
- 内联第三方依赖到自己的包中
- [译] Go语言inline内联的策略与限制
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。