Go-逃逸分析

首先解释什么是逃逸:

用于确定程序中对象的生命周期是否局限在方法内部。如果一个对象在方法内创建,并且在方法结束后不再被引用,那么该对象可以被认为是不逃逸的,即其生命周期局限在方法内部。相反,如果一个对象在方法内创建后被返回给调用者,或者被赋值给方法外部的引用,那么该对象就会逃逸出方法的作用域。

逃逸分析

分析指针动态范围的方法被称之为逃逸分析。通俗来讲,当一个对象的指针被多个方法或线程引用时,则称这个指针发生了逃逸。逃逸分析决定一个变量是分配在堆上还是分配在栈上。

逃逸分析的作用

逃逸分析把变量合理的分配到他该去的地方

go的编译器会自动的进行逃逸分析

如果编译器发现这块内存在退出函数后就没有使用了,那就分配到栈上,栈上的内存分配比堆上快很多

如果编译器分析这块内存在退出函数之后还继续使用,就会分配到堆上按需分配

栈可以自动清理 , 堆要借助gc ,堆上面变量太多又会频繁的引起gc,gc又会占用比较大的系统开销

堆和栈相比:堆适合不可预知大小的内存分配,但是代价是分配速度比较慢,会形成内存碎片

栈内存分配非常快,并且会自动释放

目的就是 通过逃逸分析,可以尽量把那些不需要分配到堆上的变量直接分配到栈上,堆上的变量少了,会减轻堆内存分配的开销,同时减少垃圾回收,提高程序运行速度

逃逸分析过程

go最基本的逃逸分析原则:如果一个函数返回对一个变量的引用,那么这个变量就会发生逃逸

编译器通过分析代码来决定将变量分配到何处

变量在函数外部没有被引用,优先放到栈上

变量在函数外部存在引用,必定放到堆上

分析的命令行

复制代码
go build -gcflags '-m-l' main.go

GO中的堆栈

c/c++ 中的堆栈,操作系统自动维护一个所启动程序消耗内存的地址空间,将这个空间逻辑上划分为堆空间和栈内存空间,这时的栈:是指程序运行时自动获取的一小块内存,在栈中自动释放的本质是可以被无条件覆盖,对于堆而言,每次申请内存,所需空间从维护的堆内存地址空间中分配出去,而在归还时则会将归还的内存合并到所维护的地址空间中

GO传统意义上的栈,go语言放入了调度器,垃圾回收,系统调用等, go中的堆和栈其实是go运行时通过管理向操作系统申请的堆内存,构造逻辑上的堆和栈,本质都是从堆申请内存得来的,

在必要的时候,go为了防止内存碎片化,会在合适的时候堆整个栈进行深度拷贝,然后放到别的地方

相关推荐
J***51688 分钟前
SpringSecurity的配置
java
面汤放盐10 分钟前
软件架构指南 Software Architecture Guide
java·微服务·devops
tkevinjd10 分钟前
JUC5(线程池)
java·线程池·多线程·juc
Tao____11 分钟前
如何对接Modbus-tcp协议(使用Thinlinks物联网平台)
java·物联网·网络协议·tcp/ip·modbus
ZNineSun11 分钟前
GORM:Go的ORM 框架
golang·orm·gorm·crud
鱼跃鹰飞15 分钟前
经典面试题:K8S的自动缩扩容和崩溃恢复
java·容器·kubernetes
Coder_Boy_20 分钟前
Spring Boot 事务回滚异常 UnexpectedRollbackException 详解(常见问题集合)
java·spring boot·后端
青云交21 分钟前
Java 大视界 -- 基于 Java+Redis Cluster 构建分布式缓存系统:实战与一致性保障(444)
java·redis·缓存·缓存穿透·分布式缓存·一致性保障·java+redis clus
不知疲倦的仄仄22 分钟前
第五天:深度解密 Netty ByteBuf:高性能 IO 的基石
java·开源·github
xiaobaishuoAI25 分钟前
后端工程化实战指南:从规范到自动化,打造高效协作体系
java·大数据·运维·人工智能·maven·devops·geo