【Go每日面试题】内存管理

参考 小林coding

Go的内存管理

Go使用的是TCMalloc算法,本质是分级分配和本地缓存。

分配架构

三级:mcache线程缓存、mcentral中央缓存、mheap页堆。

每个P有自己的mcache,避免锁竞争;

mcentral按照对象大小来分配;

mheap向操作系统申请大块内存。

内存逃逸

简单来说就是本来应该分配在栈的对象分配到了堆上,而根据栈和堆的特点,栈是在函数结束后能自动回收,而堆需要GC垃圾回收,导致浪费。

内存逃逸的情况

  1. 返回局部变量的指针 局部变量无法在函数退出时自动回收
  2. 动态扩容(map/slice) 无法在编译器确定大小
  3. interfce{} 因为需要运行时的类型信息
  4. 闭包引用外部变量 被闭包捕获的变量逃逸到堆上

内存泄漏

简单来说就是,无法被回收导致泄露。

出现的情况

  1. goroutine 比如等待写入channel或者等待从channel中接收,死循环等,无法正常退出的情况。
  2. channel 未使用的channel和等待的channel互相持有goroutine。
  3. map过大 map删除不会释放内存,而是标记删除(标记为空闲)不释放内存,等待GC回收。
  4. slice 一个小的slice引用大的slice,大的也不会被释放(因为底层是共享数组),需要拷贝出一个新的小slice。

解决方案

  1. goroutine 用context设置超时,保证goroutine有退出机制。
  2. slice 拷贝独立小slice副本。
  3. channel 用select+default,保证channel能结束。
相关推荐
浮尘笔记2 小时前
Java Snowy框架CI/CD云效自动化部署流程
java·运维·服务器·阿里云·ci/cd·自动化
kkeeper~8 小时前
0基础C语言积跬步之深入理解指针(5下)
c语言·开发语言
一直不明飞行9 小时前
Java的equals(),hashCode()应该在什么时候重写
java·开发语言·jvm
REDcker9 小时前
有限状态机与状态模式详解 FSM建模Java状态模式与C++表驱动模板实践
java·c++·状态模式
盲敲代码的阿豪9 小时前
Python 入门基础教程(爬虫前置版)
开发语言·爬虫·python
你的保护色9 小时前
【无标题】
java·服务器·网络
basketball6169 小时前
C++ 构造函数完全指南:从入门到进阶
java·开发语言·c++
互联科技报10 小时前
2026超融合选型:Top5品牌与市场格局解读
开发语言·perl
weixin1997010801610 小时前
[特殊字符] 智能数据采集:数字化转型的“数据石油勘探队”(附Python实战源码)
开发语言·python
淘矿人10 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops