微信号:gh_eb023c6a602f

介绍:雨痕学堂

Go 性能优化技巧 9\/10

2016-05-04 07:11 雨痕

作为内置类型,通道(channel)从运行时得到很多支持,其自身设计也算得上精巧。但不管怎么说,它本质上依旧是一种队列,当多个 goroutine 并发操作时,免不了要使用锁。某些时候,这种竞争机制,会导致性能问题。


下面是一个简单利用 channel 收发数据的示例,为便于 “准确” 测量收发操作性能,我们将 make channel 操作放到外部,尽可能避免额外消耗。




在研究 go runtime 源码实现过程中,会看到大量利用 “批操作” 来提升性能的样例。在此,我们可借鉴一下,看看效果对比。






从测试结果看,性能提升很高,可见批操作是一种有效方案。


就此例而言,是否可以使用 slice 代替 array 块?直观上,slice 可减少通过 channel 传递的数据大小,减少数据复制,似乎可进一步提升性能。不妨做个测试。






其结果和前面某章类似,slice 非但没有提升性能,反而在堆上分配了更多内存,有些得不偿失。当然,这个案例未必就是绝对的,所有的性能提升都需依照具体上下文来分析。


了解更多内容请关注
雨痕学堂


 
雨痕学堂 更多文章 Go: Readonly Variable Go 性能优化技巧 10\/10 Go 性能优化技巧 8\/10 Go 性能优化技巧 7\/10 Go 性能优化技巧 6\/10
猜您喜欢 如何通过第三方工具提高电商数据转化 关于前端开发的20篇文档与指南 听说 libevent 的并发工作做得很好? App架构之组件化理解 Linux堆溢出漏洞利用之unlink