0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

golang内存分配

京东云 来源:钱文 作者:钱文 2025-03-31 15:00 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

作者:钱文

Go 的分配采用了类似 tcmalloc 的结构.特点: 使用一小块一小块的连续内存页, 进行分配某个范围大小的内存需求. 比如某个连续 8KB 专门用于分配 17-24 字节,以此减少内存碎片. 线程拥有一定的 cache, 可用于无锁分配.

同时 Go 对于 GC 后回收的内存页, 并不是马上归还给操作系统, 而是会延迟归还, 用于满足未来的内存需求.

wKgZO2fqPaqAXFq9AAWdjb5KQUo810.png



在 1.10 以前 go 的堆地址空间是线性连续扩展的, 比如在 1.10(linux amd64)中, 最大可扩展到 512GB. 因为 go 在 gc 的时候会根据拿到的指针地址来判断是否位于 go 的 heap 的, 以及找到其对应的 span, 其判断机制需要 gc heap 是连续的. 但是连续扩展有个问题, cgo 中的代码(尤其是 32 位系统上)可能会占用未来会用于 go heap 的内存. 这样在扩展 go heap 时, mmap 出现不连续的地址, 导致运行时 throw.

在 1.11 中, 改用了稀疏索引的方式来管理整体的内存. 可以超过 512G 内存, 也可以允许内存空间扩展时不连续.在全局的 mheap struct 中有个 arenas 二阶数组, 在 linux amd64 上,一阶只有一个 slot, 二阶有 4M 个 slot, 每个 slot 指向一个 heapArena 结构, 每个 heapArena 结构可以管理 64M 内存, 所以在新的版本中, go 可以管理 4M*64M=256TB 内存, 即目前 64 位机器中 48bit 的寻址总线全部 256TB 内存.

wKgZPGfqPauAbJ3LAAlqCZKg9HA739.png



go 的内存分配类似于 tcmalloc, 采用了 span 机制来减少内存碎片. 每个 span 管理 8KB 整数倍的内存, 用于分配一定范围的内存需求.


审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 内存分配
    +关注

    关注

    0

    文章

    17

    浏览量

    8525
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    从代码执行看单片机内存分配

    怎么分配和存储的,这些问题都和内寸有关系。 首先,单片机的内存可以大小分为ram和rom,这里就不再解释ram和rom的区别了,我们可以将其等效为flash和sram,其中根据flash和sram的定义
    发表于 12-02 07:58

    如何为蜂鸟添加DDR内存扩展

    本队伍编号CICC3042,本文介绍如何为蜂鸟添加DDR内存扩展。一些需要大存储空间的设计中经常需要使用DDR,这时我们希望蜂鸟可以访问DDR,以实现更好的软硬件协同。 简单阅读蜂鸟的代码发现
    发表于 10-31 06:07

    时标分配器、时间信号分配器、时钟分配

    时钟分配仪器仪表
    西安同步电子科技有限公司
    发布于 :2025年10月22日 10:40:51

    STM32H7使用Serial V2框架配合DMA,可以修改DMA的buffer内存位置吗?

    因为主内存设置在了dtcm,不能被dma访问,然而serial v2框架开启dma,缓存使用的是动态分配内存,要如何修改buffer位置呢
    发表于 10-09 07:04

    FAQ_MA35_Family M4 RAM如何调整M4的内存分配

    FAQ_MA35_Family M4 RAM如何调整M4的内存分配
    发表于 09-02 06:07

    【HZ-T536开发板免费体验】5、安装sqlite3和使用golang读写数据库

    如果想在嵌入式设备上实现简单的设备管理功能,需要数据库和服务后端程序。服务端程序,我更倾向使用golang来实现。 安装sqlite3,使用ubuntu环境,可以直接用apt install安装程序
    发表于 08-26 00:04

    灵活高效ZBUFF — C内存数据操作库:优化内存管理的利器

    在C语言开发中,高效的内存管理是提升程序性能的关键。ZBUFF作为一款灵活高效的内存数据操作库,通过优化内存分配与释放机制,为开发者提供了更简洁、更安全的API接口,极大地简化了复杂数
    的头像 发表于 08-14 18:01 516次阅读
    灵活高效ZBUFF — C<b class='flag-5'>内存</b>数据操作库:优化<b class='flag-5'>内存</b>管理的利器

    RTOS怎么实现共享内存

    K230的RTOS支持POSIX标准的共享内存吗 我尝试使用却失败 还是说需要源码部分配置的开启才可以使用 求教大佬
    发表于 08-04 08:06

    五路有源功率分配器 skyworksinc

    电子发烧友网为你提供()五路有源功率分配器相关产品参数、数据手册,更有五路有源功率分配器的引脚图、接线图、封装手册、中文资料、英文资料,五路有源功率分配器真值表,五路有源功率分配器管脚
    发表于 07-30 18:33
    五路有源功率<b class='flag-5'>分配</b>器 skyworksinc

    如何使用LAX_CODEGEN启用动态内存分配

    我目前正在探索NXP_MBDToolbox_LAX。lax_codegen 生成的代码基于静态分配。我想管理大型向量,如何使用 LAX_CODEGEN 启用动态内存分配
    发表于 04-10 08:09

    如何查看S32DS中S32平台的内存分配

    大家好,我正在使用 s32DS for s32 平台,我想查看我的项目的内存分配。我想知道分配给对象的内存以及它们被分配到哪里,例如 SRA
    发表于 04-09 07:30

    快速搞懂C语言程序内存分区!

    到动态分配的数据等内容。(内存分区图示)理解这些内存分区的结构和特性,不仅有助于编写更高效的代码,还能帮助排查和解决如段错误、内存泄漏、栈溢出等常见问题。以下是常见的六
    的头像 发表于 03-14 17:37 1327次阅读
    快速搞懂C语言程序<b class='flag-5'>内存</b>分区!

    hyper v 内存,hyper v 内存设置的操作步骤和方法是什么?

    在利用Hyper-V搭建和管理虚拟机的过程中,合理设置虚拟机的内存至关重要。内存分配是否恰当,会直接影响到虚拟机的运行性能和稳定性。若内存分配
    的头像 发表于 01-24 15:22 1091次阅读
    hyper v <b class='flag-5'>内存</b>,hyper v <b class='flag-5'>内存</b>设置的操作步骤和方法是什么?

    信道分配算法在通信中的应用

    在现代通信系统中,信道分配算法是确保有效、高效通信的关键技术之一。随着移动通信技术的快速发展,用户数量的增加和数据流量的爆炸式增长,对信道资源的需求也在不断上升。 信道分配算法的基本概念 信道分配
    的头像 发表于 01-22 16:22 1185次阅读

    云计算环境下的IP地址分配方式

    之前我们聊过在计算机环境下IP地址的分配方式,但在云计算环境下,IP地址的分配方式更加灵活,可以根据实际需求进行配置,用来满足不同企业和应用的需求。 在云计算环境中,IP地址分配主要涉及到云服务
    的头像 发表于 12-19 14:02 841次阅读