当前位置: 首页 > news >正文

go 内存分配

关注 go 语言内存分配策略,主要是想了解 go 的性能。申请不同大小的内存,性能开销是有差别的,申请内存越大,耗时也越久,性能也越差。

内存分配

参考 Go1.17.13 版本源码,从内存分配大小上区分了 tiny、small、large 3种对象类型,具体实现细节在函数 mallocgc
中。代码的逻辑结构如下:

if size <= maxSmallSize {if noscan && size < maxTinySize {} else {}
} else {
}

small 和 large 的区分标准是 32kb,小于等于 32kb 都属于 small 对象,而 tiny 需要小于 16byte。tiny 内存分配还限制了对象类型, noscan 用来标识对象中不包含指针类型。

小对象的申请

小对象的申请比较简单,下面这几行源码可以清晰的描述流程:c 表示当前的 mcache,首先计算小对象对应的 spanClass,然后尝试获取对应 span 链表中第一个空内存块,如果获取失败,尝试通过 nextFree 获取。

	size = uintptr(class_to_size[sizeclass])spc := makeSpanClass(sizeclass, noscan)span = c.alloc[spc]v := nextFreeFast(span)if v == 0 {v, span, shouldhelpgc = c.nextFree(spc)}

c.alloc 是长度为 136 的数组类型,每个 sizeclass 分别对应了 noscan 和 scan 两种类型的内存分配。通过函数 makeSpanClass 可以计算出 alloc 数组的下标,同类型的 noscan、scan 交替出现。

func makeSpanClass(sizeclass uint8, noscan bool) spanClass {return spanClass(sizeclass<<1) | spanClass(bool2int(noscan))
}
  • 逃逸分析反思
  • go size class 内存分配思考
  • Go参考TcMalloc内存分配
http://www.lryc.cn/news/106394.html

相关文章:

  • Maven pom.xml文件中build,plugin标签的具体使用
  • 批量插入数据、MVC三层分离
  • 【IMX6ULL驱动开发学习】21.Linux驱动之PWM子系统(以SG90舵机为例)
  • el-cascader级联选择器加载远程数据、默认开始加载固定条、可以根据搜索加载远程数据。
  • 大数据技术之Clickhouse---入门篇---SQL操作、副本
  • 【Rust 基础篇】Rust Sized Trait:理解Sized Trait与动态大小类型
  • 前端框架学习-Vue(三)
  • HTML <rt> 标签
  • VMware Linux Centos 配置网络并设置为静态ip
  • 【Leetcode 30天Pandas挑战】学习记录
  • 微信小程序使用 canvas 2d 实现签字板组件
  • 区块链赋能新时代司法体系,中移链打造可信存证服务
  • ELK报错no handler found for uri and method [PUT] 原因
  • Sublime操作技巧笔记
  • JVM | 基于类加载的一次完全实践
  • Termux实现电脑端远程操作【开启SSH的完整教程】
  • java(Collection类)
  • VS2019编译安装OpenMesh8.0
  • Python爬虫遇到URL错误解决办法大全
  • 基于Vue+ElementUI+Echarts+G2Plot的大屏设计器,代码完全开源
  • Linux - PostgreSQL 适用于9.x 以上的 tar.gz 源码安装与理解 - 报错集锦
  • Django使用用户列表的展示和添加
  • kubernetes错误汇总
  • [openCV]基于拟合中线的智能车巡线方案V4
  • 【网络云盘客户端】——上传文件的功能的实现
  • WebView2对比CefSharp的超强优势
  • 前端需要知道的计算机网络知识
  • [2023杭电多校5 1005] Snake (生成函数)
  • 【MyBtis】各种查询功能
  • H5打包封装小程序系统开发