Go性能优化技巧2/10
2016-07-12 00:00
127 查看
对于一些初学者,自知道 Go 里面的 array 以 pass-by-value 方式传递后,就莫名地引起 “恐慌”。外加诸多文章未作说明,就建议用 slice 代替 array,企图避免数据拷贝,提升性能。实际上,此做法有待商榷。某些时候怕会适得其反,倒造成不必要的性能损失。
用个简单的示例说明。
代码很简单,两个函数分别返回 “内容相同” 的 array 和 slice。为避免编译器优化,特填充了全部数据,以模拟 “真实” 数据复制行为。接下来,看看性能测试对比。
这结果怕是颠覆了最初认知。array 非但拥有更好的性能,还避免了堆内存分配,也就是说减轻了 GC 压力。为什么会这样?
熟悉汇编的,怕是很容易看出来。函数 array 返回值的复制只需用 "CX + REP" 指令就可完成。
整个 array 函数完全在栈上完成,而 slice 函数则需执行 makeslice,继而在堆上分配内存,这就是问题所在。
对于一些短小的对象,复制成本远小于在堆上分配和回收操作。
Go Proverbs: A little copying is better than a little dependency.
用个简单的示例说明。
代码很简单,两个函数分别返回 “内容相同” 的 array 和 slice。为避免编译器优化,特填充了全部数据,以模拟 “真实” 数据复制行为。接下来,看看性能测试对比。
这结果怕是颠覆了最初认知。array 非但拥有更好的性能,还避免了堆内存分配,也就是说减轻了 GC 压力。为什么会这样?
熟悉汇编的,怕是很容易看出来。函数 array 返回值的复制只需用 "CX + REP" 指令就可完成。
整个 array 函数完全在栈上完成,而 slice 函数则需执行 makeslice,继而在堆上分配内存,这就是问题所在。
对于一些短小的对象,复制成本远小于在堆上分配和回收操作。
Go Proverbs: A little copying is better than a little dependency.
相关文章推荐
- Go 性能优化技巧 3/10
- Go 性能优化技巧 4/10
- Go 性能优化技巧 5/10
- Go 性能优化技巧 6/10
- Go 性能优化技巧 7/10
- Go 性能优化技巧 8/10
- HDU5546 Ancient Go DFS
- goldengate 学习有用网址
- GO的GDB调试
- 统一日志管理-Mongo 篇
- 大话设计模式(Golang) 二、策略模式
- Django开发环境的搭建
- golang学习之rpc实例
- 最新的黑客大杀器:Google Dorking
- mongoose
- Is it Google Hacking? It's Google Dorking
- 欢迎使用CSDN-markdown编辑器
- pycharm快捷键、配置virtualenv环境,配置django调试,配置远程调试
- Go语言_Go_Golang 逐行读取文件
- web流量/镜像复制工具——gor