高性能go语言 | 青训营笔记

29 阅读1分钟

这是我参与「第五届青训营」笔记创作活动的第11天

性能优化是提升软件系统处理能力,减少不必要的消耗,充分挖掘计算机算力

性能优化能带给用户更好的体验,降低成本提高效率

性能优化有业务层优化和语言运行时优化

业务层优化针对特定的场景,具体问题具体分析。容易获得较大性能受益

语言运行时优化,解决更通用的性能问题,考虑更多场景。

在性能优化中,软件质量至关重要,在保证接口稳定的前提下改进具体实现。

此时测试用例要覆盖尽可能多的场景,方便回归。

文档要写做了什么没做什么,能达到怎样的效果。

隔离,通过选项控制是否开启优化。

可观测,必要的日志输出。

自动内存管理

动态内存:程序在运行时根据需求动态分配的内存:malloc()

自动内存管理(垃圾回收):由程序语言的运行时系统管理动态内存。避免手动内存管理,专注于实现业务逻辑,保证内存使用的正确性和安全性。

分为三个任务,为新对象分配空间,找到存活对象,回收死亡对象的内存空间。

mutator:业务线程,分配新对象,修改对象指向关系

collector:GC线程,找到存货活对象,回收死亡对象的内存空间

serial GC:只有一个collector

parallel GC:支持多个collector同时回收的GC算法

concurrent GC:mutator和collector可以同时执行