Go 性能优化技巧 2/10
来源:互联网 发布:中华小说网源码 编辑:程序博客网 时间:2024/05/16 11:16
对于一些初学者,自知道 Go 里面的 array 以 pass-by-value 方式传递后,就莫名地引起 “恐慌”。外加诸多文章未作说明,就建议用 slice 代替 array,企图避免数据拷贝,提升性能。实际上,此做法有待商榷。某些时候怕会适得其反,倒造成不必要的性能损失。
用个简单的示例说明。
package mainimport ( "fmt")const capacity = 1024func array() [capacity]int { var d [capacity]int for i := 0; i < len(d); i++ { d[i] = 1 } return d}func slice() []int { d := make([]int, capacity) for i := 0; i < len(d); i++ { d[i] = 1 } return d}func main() { fmt.Println(array()) fmt.Println(slice())}
代码很简单,两个函数分别返回 “内容相同” 的 array 和 slice。为避免编译器优化,特填充了全部数据,以模拟 “真实” 数据复制行为。接下来,看看性能测试对比。
package mainimport ( "testing")func BenchmarkArray(b *testing.B) { for i := 0; i < b.N; i++ { _ = array() }}func BenchmarkSlice(b *testing.B) { for i := 0; i < b.N; i++ { _ = slice() }}
这结果怕是颠覆了最初认知。array 非但拥有更好的性能,还避免了堆内存分配,也就是说减轻了 GC 压力。为什么会这样?
熟悉汇编的,怕是很容易看出来。函数 array 返回值的复制只需用 "CX + REP" 指令就可完成。
整个 array 函数完全在栈上完成,而 slice 函数则需执行 makeslice,继而在堆上分配内存,这就是问题所在。
对于一些短小的对象,复制成本远小于在堆上分配和回收操作。
Go Proverbs: A little copying is better than a little dependency.
最新动态,请扫码关注
1 0
- Go 性能优化技巧 2/10
- Go 性能优化技巧 10/10
- Go性能优化技巧 1/10
- Go 性能优化技巧 3/10
- Go 性能优化技巧 4/10
- Go 性能优化技巧 5/10
- Go 性能优化技巧 6/10
- Go 性能优化技巧 7/10
- Go 性能优化技巧 8/10
- Go 性能优化技巧 9/10
- 【golang】Go 性能优化技巧
- Go高性能编程技巧2
- Go高性能编程技巧
- Go高性能编程技巧
- Java 性能优化技巧集锦 (2)
- Java 性能优化技巧集锦 (2)
- Java性能优化技巧集锦(2)
- Apache性能优化技巧
- Android 实现复制到系统剪贴板 TextView 实现单行输入,禁止换行,多出来的显示省略号
- java 枚举enum的本来源码
- 第十周项目1 点-圆-圆柱的继承设计
- POJ 1995 多项式求和取模
- 文章标题
- Go 性能优化技巧 2/10
- 正则表达式学习笔记
- ExtJS -- 改变树节点图标 tree
- 生活杂文
- 程序员的成长和代码行数的关系
- 对话:一个工程师在蘑菇街4年的架构感悟
- ExtJS -- 各种Store
- iOS 取得ipa里面的图片
- 58-Odd Even Linked List