为什么golang pprof检测出的内存占用远小于top命令查看到的内存占用量?

56 阅读1分钟

www.zhihu.com/question/45…

可以简单理解为,go应用会先申请一批内放在自己那,运行时实际使用到的部分还没有那么多,pprof检测到的是运行时的,而top看到的是[应用进程]本身的,因此会有一定的差异。

Go的内存分配的核心思想可以分为以下几点: 每次从操作系统申请一大块儿的内存,由Go来对这块儿内存做分配,减少系统调用+ 内存分配算法采用Google的 TCMalloc算法。算法比较复杂,究其原理可自行查阅。其核心思想 就是把内存切分的非常的细小,分为多级管理,以降低锁的粒度。,, 回收对象内存时,并没有将其真正释放掉,只是放回预先分配的大块内存中,以便复用。只有内 存闲置过多的时候,才会尝试归还部分内存给操作系统,降低整体开销,