广告位联系
返回顶部
分享到

GoLang sync.Pool的介绍与用法

Golang 来源:互联网 作者:佚名 发布时间:2023-06-20 22:53:08 人浏览
摘要

一句话总结:保存和复用临时对象,减少内存分配,降低GC压力 sync.Pool是可伸缩的,也是并发安全的,其大小仅受限于内存大小。sync.Pool用于存储那些被分配了但是没有使用,而未来可

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

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

使用方法

声明对象池

1

2

3

4

5

6

7

8

9

10

11

12

type Student struct {

   Name   string

   Age    int32

   Remark [1024]byte

}

func main() {

   var studentPool = sync.Pool{

      New: func() interface{} {

         return new(Student)

      },

   }

}

Get & Put

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

type Student struct {

   Name   string

   Age    int32

   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()则是在对象使用完毕之后,返回对象池

性能测试

以下是性能测试的代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

package benchmem

import (

   "encoding/json"

   "sync"

   "testing"

)

type Student struct {

   Name   string

   Age    int32

   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: windows
goarch: amd64                                      
pkg: ginTest                                       
cpu: 11th Gen Intel(R) Core(TM) i5-1135G7 @ 2.40GHz
BenchmarkUnmarshal-8               17004             74103 ns/op            1392 B/op          8 allocs/op
BenchmarkUnmarshalWithPool-8       17001             71173 ns/op             240 B/op          7 allocs/op
PASS
ok      ginTest 3.923s

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

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


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 :
相关文章
  • Go框架三件套Gorm Kitex Hertz基本用法与常见API介绍
    Gorm、Kitex、Hertz的基本用法与常见的API讲解 Gorm gorm是Golang语言中一个已经迭代数十年且功能强大、性能极好的ORM框架 ORM:Object Relational Map
  • GoLang sync.Pool的介绍与用法
    一句话总结:保存和复用临时对象,减少内存分配,降低GC压力 sync.Pool是可伸缩的,也是并发安全的,其大小仅受限于内存大小。sync.Pool用
  • Windows下升级go版本过程介绍
    首次安装需要在官网下载 msi 安装包,安装完后 golang 会自动设置环境变量。在命令行可以使用 go version 查看版本信息。 后续如果需要升级
  • GO利用channel协调协程的实现介绍
    go 当中的并发编程是通过goroutine来实现的,利用channel(管道)可以在协程之间传递数据,实现协程的协调与同步。 使用 新建一个管道,使
  • Golang实现CronJob(定时任务)的方法
    最近做了一个需求,是定时任务相关的。以前定时任务都是通过 linux crontab 去实现的,现在服务上云(k8s)了,尝试了 k8s 的 CronJob,由于公司
  • goland中导包报红和go mod问题

    goland中导包报红和go mod问题
    goland导包报红 1. 原理 import的包有两类: (1)在go.mod中有地址的,这种需要拉到gopath/pkg下 (2)没在go.mod的,这种在项目里,import的路径需
  • Hugo游乐场内容初始化示例介绍
    使用Hugo构建站点的体验很棒。 首先是构建速度快,其次是使用起来简单,一个hugo命令,我们的站点就已经就绪。 在构建过程中,Hugo提供了
  • 使用Golang快速构建出命令行应用程序
    在日常开发中,大家对命令行工具(CLI)想必特别熟悉了,如果说你不知道命令工具,那你可能是个假开发。每天都会使用大量的命令行工
  • go开源Hugo站点渲染之模板词法解析

    go开源Hugo站点渲染之模板词法解析
    Deps在准备好NewPathSpec,NewSpec,NewContentSpec,NewSourceSpec后,调用onCreate正式创建HugoSites,并在最后一步,加载模板执行器。 模板执行器只是提
  • 向Rust学习Go考虑简单字符串插值特性示例解析
    fmt.Printf或fmt.Sprintf写拼装字符串业务 在日常开发 Go 工程中,我们经常会用fmt.Printf或fmt.Sprintf去写类似的拼装字符串的业务。 如下代码:
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计