美文网首页Golang随笔-生活工作点滴
Go 内存管理 -- 内存分配 二

Go 内存管理 -- 内存分配 二

作者: 邹志全 | 来源:发表于2019-07-15 22:18 被阅读28次

接上一篇,下面来看看内存分配的初始化分配等。

初始化

首先会申请一段连续的内存空间以供使用,大小(64位机器上)512M(spans_mapped)+16G(bitmap_mapped)+512G(arena)。
hmap初始化的源码在src/runtime/proc.go中,大家可以参照本文看一下。
mheap初始化

func (h *mheap) init(spansStart, spansBytes uintptr) 

1、初始化空间
2、mcentral初始化
3、spans初始化
mheap具体的初始化发生在mallocinit()函数中(被schedinit()调用):

func mallocinit()

1、检查系统/硬件信息
2、 计算预留空间大小
3、尝试预留地址
4、初始化mheap中的一部分变量
5、其他部分初始化,67个mcentral在这里初始化
mcentral 初始化
1、设置自己的级别
2、将两个mspanList初始化
mcache

func procresize(nprocs int32) *p

而mcache的初始化在func procresize(nprocs int32)中,procresize也在schedinit()中调用,顺序在mallocinit()之后,所以说也就是说mcentral先初始化,然后是mheap.
allocmcache
allocmcache初始化比较简单,直接看下源码吧:

func allocmcache() *mcache {
    lock(&mheap_.lock)
    c := (*mcache)(mheap_.cachealloc.alloc())
    unlock(&mheap_.lock)
    for i := 0; i < _NumSizeClasses; i++ {
        c.alloc[i] = &emptymspan
    }
    c.next_sample = nextSample()
    return c
}

这几个函数执行完,管理结构、mheap、67个mcentral及每个goroutine的mcache都初始化完毕。

内存分配

针对于不同大小的的对象,go的分配策略是不同的:
(0, 16B) 且不包含指针的对象: Tiny分配
(0, 16B) 包含指针的对象:正常分配
[16B, 32KB] : 正常分配
(32KB, -) : 大对象分配
Tiny分配和大对象分配都属于内存管理的优化范畴,这里就仅看正常分配。
1、获取当前线程的私有缓存mcache
2、跟据size计算出适合的class的id
3、从mcache的alloc[class]数组中找到可用的span
4、如果mcache没有可用的span,则从mcentral申请一个新的span加入mcache中。
5、如果mcentral中也没有可用的span,则从mheap中申请一个新的span加入mcentral。(这里大家可以注意下mcache、mcentral、mheap的层级关系)
6、从该span中获取到空闲对象地址并返回。
go的内存分配非常复杂,中间还有很多GC的细节在里面,一言半语的也说不详细,大家可以对着简单的纲要直接看源码,注释也非常详细,一定要对照上一篇的图来理解go内存管理。

相关文章

  • 图解 Go 内存管理器的内存分配策略

    关于Go的内存分配 在 Go 语言里,从内存的分配到不再使用后内存的回收等等这些内存管理工作都是由 Go 在底层完...

  • Go 内存管理 -- 内存分配 二

    接上一篇,下面来看看内存分配的初始化、分配等。 初始化 首先会申请一段连续的内存空间以供使用,大小(64位机器上)...

  • go-内存机制(3)

    go的内存分配 Golang有一套自己的内存管理机制,自主的去完成内存分配、垃圾回收、内存管理等过程,从而避免频繁...

  • Golang源码之图解内存分配

    转载自图解Go语言内存分配 Go语言内置运行时(就是runtime),抛弃了传统的内存分配方式,改为自主管理。这样...

  • Go内存分配机制总结

    GO语言内存管理子系统主要由两部分组成:内存分配器和垃圾回收器(gc)。内存分配器主要解决小对象的分配管理和多线程...

  • Go语言——内存管理

    Go语言——内存管理 参考: 图解 TCMalloc Golang 内存管理 Go 内存管理 问题 内存碎片:避免...

  • Go 内存管理 -- 内存分配 一

    前言 go作为一个比较新晚(新)的语言,自然借鉴前辈们的优点,比如说语言本身负责内存管理、对协程和高并发的高优支持...

  • 操作系统之内存管理

    内存管理 包括内存管理和虚拟内存管理 内存管理包括内存管理概念、交换与覆盖、连续分配管理方式和非连续分配管理方式(...

  • JVM 内存管理

    内存管理=内存分配+内存回收 内存分配 JMM指Java内存管理线程之间的共享变量存储在主内存(main memo...

  • Java中四种引用

    Java内存管理包括内存分配和内存回收。 内存分配:程序员通过new对象,JVM会自动为该对象分配内存。 内存回收...

网友评论

    本文标题:Go 内存管理 -- 内存分配 二

    本文链接:https://www.haomeiwen.com/subject/hwjhkctx.html