Go 语言内存管理详解

简介: Go 语言内存管理详解

性能优化

性能优化的层面

  • 业务代码
  • SDK
  • 基础库
  • 语言运行时
  • OS

确保SDK质量:

    软件质量至关重要
    在保证接口稳定的前提下改进具体实现
    测试用例:覆盖尽可能多的场景,方便回归
    文档:做了什么,没做什么,能达到怎样的效果
    隔离:通过选项控制是否哥启优化
    可观测:必要的日志输出

自动内存管理

动态内存:
    ·程序在运行时根据需求动态分配的内存: malloc()
自动内存管理(垃圾回收):由程序语言的运行时系统回收动态内存:
    ·避免手动内存管理,专注于实现业务逻辑
    ·保证内存使用的正确性和安全性: double-free problem, use-after-free problem
三个任务:
    ·为新对象分配空间。找到存活对象
    ·回收死亡对象的内存空间

相关概念

Mutator:业务线程,分配新对象,修改对象指向关系
Collector: GC线程,找到存活对象,回收死亡对象的内存空间
Serial GC:只有一个collector
Parallel GC:支持多个collectors同时回收的GC算法
Concurrent GC: mutator(s)和collector(s)可以同时执行
    Collectors必须感知对象指向关系的改变!
        已标记对象指向的对象必须被标记

image.png

·评价GC算法
    ·安全性(Safety):不能回收存活的对象 基本要求
    ·吞吐率(Throughput):1-GC时间/程序执行总时间 花在GC上的时间

    ·暂停时间(Pause time): stop the world (STW)业务是否感知
    ·内存开销(Space overhead) GC元数据开销
·追踪垃圾回收(Tracing garbage collection)。
·引用计数(Reference counting)

追踪垃圾回收

·对象被回收的条件:指针指向关系不可达的对象。
·标记根对象:
·标记:找到可达对象。
·清理:所有不可达对象.
      ·将存活对象复制到另外的内存空间(Copying GC)·
      ·将死亡对象的内存标记为“可分配”(Mark-sweep GC)。
      ·移动并整理存活对象(Mark-compact GC)
·根据对象的生命周期,使用不同的标记和清理策略:

分代GC

·分代假说(Generational hypothesis):most objects die young. 
·Intuition :很多对象在分配出来后很快就不再使用了
·每个对象都有年龄 :经历过GC的次数
·目的 :对年轻和老年的对象,制定不同的GC 策略,降低整体内存管理的开销
·不同年龄的对象处于heap的不同区域

·年轻代(Young generation)
    常规的对象分配
    由于存活对象很少,
    可以采用copying collection. GC吞吐率很高
·老年代(Old generation)
    对象趋向于一直活着,反复复制开销较大·
    可以采用mark-sweep collection

引用计数

·每个对象都有一个与之关联的引用数目
·对象存活的条件:当且仅当引用数大于0
优点
    ·内存管理的操作被平摊到程序执行过程中
    ·内存管理不需要了解runtime的实现细节:C++智能指针(smart pointer)。
缺点
    ·维护引用计数的开销较大:通过原子操作保证对引用计数操作的原子性和可见性·无法回收环形数据结构——weak reference
    ·内存开销:每个对象都引入的额外内存空间存储引用数目。回收内存时依然可能引发暂停
相关文章
|
20天前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
64 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
1月前
|
存储 Go 索引
go语言中数组和切片
go语言中数组和切片
43 7
|
1月前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。
|
1月前
|
程序员 Go
go语言中结构体(Struct)
go语言中结构体(Struct)
106 71
|
1月前
|
存储 Go 索引
go语言中的数组(Array)
go语言中的数组(Array)
110 67
|
5天前
|
监控 安全 算法
深度剖析核心科技:Go 语言赋能局域网管理监控软件进阶之旅
在局域网管理监控中,跳表作为一种高效的数据结构,能显著提升流量索引和查询效率。基于Go语言的跳表实现,通过随机化索引层生成、插入和搜索功能,在高并发场景下展现卓越性能。跳表将查询时间复杂度优化至O(log n),助力实时监控异常流量,保障网络安全与稳定。示例代码展示了其在实际应用中的精妙之处。
27 9
|
14天前
|
算法 安全 Go
Go 语言中实现 RSA 加解密、签名验证算法
随着互联网的发展,安全需求日益增长。非对称加密算法RSA成为密码学中的重要代表。本文介绍如何使用Go语言和[forgoer/openssl](https://github.com/forgoer/openssl)库简化RSA加解密操作,包括秘钥生成、加解密及签名验证。该库还支持AES、DES等常用算法,安装简便,代码示例清晰易懂。
47 12
|
1月前
|
存储 Go
go语言中映射
go语言中映射
42 11
|
17天前
|
监控 算法 安全
解锁企业计算机监控的关键:基于 Go 语言的精准洞察算法
企业计算机监控在数字化浪潮下至关重要,旨在保障信息资产安全与高效运营。利用Go语言的并发编程和系统交互能力,通过进程监控、网络行为分析及应用程序使用记录等手段,实时掌握计算机运行状态。具体实现包括获取进程信息、解析网络数据包、记录应用使用时长等,确保企业信息安全合规,提升工作效率。本文转载自:[VIPShare](https://www.vipshare.com)。
24 0
|
1月前
|
Go 数据安全/隐私保护 UED
优化Go语言中的网络连接:设置代理超时参数
优化Go语言中的网络连接:设置代理超时参数