为啥用了 sync.pool,反而会慢很多

2019-05-08 10:14:57 +08:00
 304464743

代码如下,用了 sync.pool 反而慢,为啥呢? 结果:withoutpool 0s
with pool 23 秒

package main

import ( "fmt" "sync" "time" )

// 一个[]byte 的对象池,每个对象为一个[]byte var bytePool = sync.Pool{ New: func() interface{} { b := make([]byte, 1024) return &b }, }

func main() { a := time.Now().Unix() // 不使用对象池 for i := 0; i < 1000000000; i++{ obj := make([]byte,1024) _ = obj } b := time.Now().Unix() // 使用对象池 for i := 0; i < 1000000000; i++{ obj := bytePool.Get().(*[]byte) _ = obj bytePool.Put(obj) } c := time.Now().Unix() fmt.Println("without pool ", b - a, "s") fmt.Println("with pool ", c - b, "s") }

2653 次点击
所在节点    Go 编程语言
5 条回复
walkerliu
2019-05-08 10:36:16 +08:00
最起码把代码用 markdown 格式 排版一下吧,这一大坨谁能看得懂你在描述什么
chennqqi
2019-05-08 10:45:38 +08:00
put get 都有锁,同样的情况每次都加锁你想能快?我想你大概没理解 pool 的用法
另外:

**最起码把代码用 markdown 格式 排版一下吧,这一大坨谁能看得懂你在描述什么**
reus
2019-05-08 10:55:49 +08:00
单一线程,生命期短,这种对象用 sync.Pool 没有意义
dreampuf
2019-05-08 11:02:24 +08:00
在第一次循环结束后调用 `runtime.GC()` 再进行比较
lol0
2019-05-08 11:39:59 +08:00
这不是搞笑吗,不用对象池的那个循环,一到下一循环上次创建的数据就没人引用了,编译器直接优化了,不管你是循环一百亿次,内存占用几乎等于 0,当然秒完

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/562079

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX