GoLang sync.Pool简介与用法

01-03 75阅读 0评论

使用?=场景

一句话总结:保存和复用临时对象,减少内存分配,降低GC压力

sync.Pool是可伸缩的,也是并发安全的,其大小仅受限于内存大小。sync.Pool用于存储那些被分配了但是没有使用,而未来可能会使用的值。这样就可以不用再次经过内存分配,可直接复用已有对象,减轻GC的压力,从而提升系统性能。

使用方法

声明对象池

type Student Struct {    Name   string    Ageint32    Remark [1024]byte } func main() {    var studentPool = sync.Pool{   New: func() interface{} {  return new(Student)   },    } } 

Get & Put

Type Student struct {    Name   string    Ageint32    Remark [1024]byte } var buf, _ = JSon.Marshal(Student{Name: "lxy", Age: 18}) func Unmarsh() {    var studentPool = sync.Pool{   New: func() interface{} {  return new(Student)   },    }    stu := studentPool.Get().(*Student)    err := json.Unmarshal(buf, stu)    if err != nil {   return    }    studentPool.Put(stu) } 
Get()用于从对象池中获取对象,因为返回值interface{},因此需要类型转换Put()则是在对象使用完毕之后,返回对象池

性能测试

以下是性能测试代码

package benchmem import (    "encoDIng/json"    "sync"    "testing" ) type Student struct {    Name   string    Ageint32    Remark [1024]byte } var buf, _ = json.Marshal(Student{Name: "lxy", Age: 18}) var studentPool = sync.Pool{    New: func() interface{} {   return new(Student)    }, } func BenchmarkUnmarshal(b *testing.B) {    for n := 0; n < b.N; n++ {   stu := &Student{}   json.Unmarshal(buf, stu)    } } func BenchmarkUnmarshalWithPool(b *testing.B) {    for n := 0; n < b.N; n++ {   stu := studentPool.Get().(*Student)   json.Unmarshal(buf, stu)   studentPool.Put(stu)    } } 

输入以下命令

Go test -bench . -benchmem

以下是性能测试的结果:

GOos: Windowsgoarch: amd64 pkg: ginTest cpu: 11th Gen Intel(R) Core(TM) i5-1135G7 @ 2.40GHzBenchmarkUnmarshal-817004 74103 ns/op 1392 B/op 8 allocs/opBenchmarkUnmarshalWithPool-817001 71173 ns/op 240 B/op 7 allocs/opPASSok ginTest 3.923s

在这个例子中,因为 Student 结构体内存占用较小,内存分配几乎不耗时间。而标准库 json 反序列化时利用了反射,效率是比较低的,占据了大部分时间,因此两种方式最终的执行时间几乎没什么变化。但是内存占用差了一个数量级,使用了 sync.Pool 后,内存占用仅为未使用的 240/1392 = 1/6,对 GC 的影响就很大了。

我们甚至在fmt.Printf的源码里面也使用了sync.Pool进行性能优化

到此这篇关于golang sync.Pool简介与用法的文章就介绍到这了,更多相关Golang sync.Pool内容请搜索云初冀北以前的文章或继续浏览下面的相关文章希望大家以后多多支持云初冀北!

免责声明
本站提供的资源,都来自网络,版权争议与本站无关,所有内容及软件的文章仅限用于学习和研究目的。不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负,我们不保证内容的长久可用性,通过使用本站内容随之而来的风险与本站无关,您必须在下载后的24个小时之内,从您的电脑/手机中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。侵删请致信E-mail:goliszhou@gmail.com
$

发表评论

表情:
评论列表 (暂无评论,75人围观)

还没有评论,来说两句吧...