温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Go的Pool并发怎么使用

发布时间:2021-12-20 14:32:43 来源:亿速云 阅读:142 作者:iii 栏目:大数据

这篇文章主要讲解了“Go的Pool并发怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Go的Pool并发怎么使用”吧!

sync.Pool 用于存储临时对象,它将使用完毕的对象存入对象池中,在需要的时候取出来重复使用,目的是为了避免重复创建相同的对象造成 GC 负担过重。从 Pool 中取出对象时,如果 Pool 中没有对象,将返回 nil,但是如果给 Pool.New 字段指定了一个函数的话,Pool 将使用该函数创建一个新对象返回。

package mainimport (    "fmt"    "sync")func main() {    sp := sync.Pool{        //创建一个Pool,并且实现New()函数        New: func() interface{}{            return "hello world"        },    }    // 第1次获取池中值    v1 := sp.Get()    fmt.Println("第1次值:", v1)    //New()返回的是interface{}通过类型断言来转换    if v1,ok := v1.(string);ok {        v1= "hello golang"        sp.Put(v1) // 获取池子中元素 然后修改值    }    // 第2次获取池中值    v2 := sp.Get()    fmt.Println("第2次值:", v2)    // 第3次获取池中值    v3 := sp.Get()    //因为池中的对象已经没有了,所以又重新通过New()创建一个新对象,放入池中,然后返回    fmt.Println("第3次值:", v3)}

打印结果

第1次值: hello world第2次值: hello golang第3次值: hello world

尝试从私有对象获取

私有对象不存在,尝试从当前Processor的共享池获取

如果当前Processor共享池是空的,那么就尝试去其他Processor的共享池获取

如果所有子池都是空的,最后就用指定的New 函数产生一个新的对象返回。

放回

如果私有对象不存在则保存为私有对象

如果私有对象存在,放入当前Processor子池的共享池

生命周期

GC会清除sync.pool缓存的对象

对象的缓存有效期为下一次GC之前

使用

适用与通过复用,降低复杂对象的创建和GC代价

协程安全,会有锁的开销

生命周期受GC影响,不适用于连接池等,需要自己管理生命周期的资源的池化

感谢各位的阅读,以上就是“Go的Pool并发怎么使用”的内容了,经过本文的学习后,相信大家对Go的Pool并发怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI