可以简单理解为,go应用会先申请一批内放在自己那,运行时实际使用到的部分还没有那么多,pprof检测到的是运行时的,而top看到的是[应用进程]本身的,因此会有一定的差异。
Go的内存分配的核心思想可以分为以下几点: 每次从操作系统申请一大块儿的内存,由Go来对这块儿内存做分配,减少系统调用+ 内存分配算法采用Google的 TCMalloc算法。算法比较复杂,究其原理可自行查阅。其核心思想 就是把内存切分的非常的细小,分为多级管理,以降低锁的粒度。,, 回收对象内存时,并没有将其真正释放掉,只是放回预先分配的大块内存中,以便复用。只有内 存闲置过多的时候,才会尝试归还部分内存给操作系统,降低整体开销,