内容简介:根据可以使用编译参数我们可以通过添加
根据 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内联的策略与限制
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
企业应用架构模式
Martin Fowler、王怀民、周斌 / 王怀民、周斌 / 机械工业出版社 / 2004-7 / 49.00元
本书作者是当今面向对象软件开发的权威,他在一组专家级合作者的帮助下,将40多种经常出现的解决方案转化成模式,最终写成这本能够应用于任何一种企业应用平台的、关于解决方案的、不可或缺的手册。本书获得了2003年度美国软件开发杂志图书类的生产效率奖和读者选择奖。本书分为两大部分。第一部分是关于如何开发企业应用的简单介绍。第二部分是本书的主体,是关于模式的详细参考手册,每个模式都给出使用方法和实现信息,并一起来看看 《企业应用架构模式》 这本书的介绍吧!