这是我参与「第五届青训营 」伴学笔记创作活动的第 6 天
性能优化是什么?
提升软件系统处理能力,减少不必要的消耗,充分发掘计算机算力。
为什么要做性能优化?
用户体验:带来用户体验的提升一让刷抖音更丝滑,让双十一购物不再卡顿
资源高效利用:降低成本,提高效率一很小的优化乘以海量机器会是显著的性能提升和成本节约
一、自动内存管理
- 动态内存
- 程序在运行时根据需求动态分配的内存:malloc()
- 自动内存管理(垃圾回收):由程序语言的运行时系统管理动态内存
- 避免手动内存管理,专注于实现业务逻辑
- 保证内存使用的正确性和安全性:double-free problem,use-after-free problem
- 三个任务
- 为新对象分配空间
- 找到存活对象
- 回收死亡对象的内存空间
- Copying GC:将对象复制到另外的内存空间
- Mark-sweep GC:使用free list管理空闲内存
- Compact GC:原地整理对象
2.Go内存管理及优化
1.Go内存分配
- 目标:为对象在heap上分配内存
- 提前将内存分块
- 调用系统调用mmap()向OS申请一大块内存,例如4 MB
- 先将内存划分成大块,例如8KB,称作mspan
- 再将大块继续划分成特定大小的小块,用于对象分配
- noscan mspan:分配不包含指针的对象——GC不需要扫描
- scan mspan:分配包含指针的对象——GC需要扫描
- 对象分配:根据对象的大小,选择最合适的块返回