go runtime

news2024/12/26 20:49:39
  1. go 运行时,也称为 go runtime,类似Java中的JVM虚拟机,不过runtime并非是虚拟机。
  2. 其本身就是每个 go 程序的一部分,它会跟源码一起编译并链接到目标程序中,即便只写了一个 hello world 程序,这个程序中也包含了 runtime 的实现。
  3. runtime 负责实现 Go 的垃圾收集、并发、内存堆栈管理以及 Go 语言的其他关键功能。
  4. Golang程序生成的可执行文件在指定平台即可运行效率很高,它和C/C++一样编译出来的是二进制可执行文件,运行Golang的程序并不需要安装类似Java虚拟机之类的东西,是因为编译时Golang会将runtime部分代码编译进去。
  5. 它大部分以标准库的形式存放在每个 Go 发布版的源码中。

在这里插入图片描述

Golang应用程序、runtime、可执行程序与操作系统之间的关系

在这里插入图片描述

如何在Go的函数中得到调用者函数名

func Caller(skip int) (pc uintptr, file string, line int, ok bool)

  1. Caller可以返回函数调用栈的某一层的程序计数器、文件信息、行号。
  2. 0 代表当前函数,也是调用runtime.Caller的函数。1 代表上一层调用者,以此类推。
函数描述
skip需要提升的堆栈帧数,0表示当前函数,1表示上一层函数...
返回值描述
pc函数指针
file函数所在文件的名称或目录名称
line函数所在文件的行号
ok是否可以获取到信息

func Callers(skip int, pc []uintptr) int

  1. Callers用来返回调用站的程序计数器, 放到一个uintptr中。
  2. 0 代表 Callers 本身,这和上面的Caller的参数的意义不一样,历史原因造成的。 1 才对应这上面的 0。
func trace(message string) string {
	var pcs [32]uintptr
	n := runtime.Callers(3, pcs[:]) // skip first 3 caller

	var str strings.Builder
	str.WriteString(message + "\nTraceback:")
	for _, pc := range pcs[:n] {
		fn := runtime.FuncForPC(pc)
		file, line := fn.FileLine(pc)
		str.WriteString(fmt.Sprintf("\n\t%s:%d", file, line))
	}
	return str.String()
}
输出结果可以看到这个goroutine的整个栈都打印出来了

func CallersFrames(callers []uintptr) *Frames

上面的Callers只是获取栈的程序计数器,如果想获得整个栈的信息,可以使用CallersFrames函数,省去遍历调用FuncForPC。

func trace2() {
	pc := make([]uintptr, 10) // at least 1 entry needed
	n := runtime.Callers(0, pc)
	frames := runtime.CallersFrames(pc[:n])
	for {
		frame, more := frames.Next()
		fmt.Printf("%s:%d %s\n", frame.File, frame.Line, frame.Function)
		if !more {
			break
		}
	}
}

func FuncForPC(pc uintptr) *Func

  1. 它可以把程序计数器地址对应的函数的信息获取出来。如果因为内联程序计数器对应多个函数,它返回最外面的函数。

  2. 它的返回值是一个Func类型的值,通过Func可以获得函数地址、文件行、函数名等信息。

Stack获取程序堆栈

  1. 在程序panic的时候,一般会自动把堆栈打出来,如果想在程序中获取堆栈信息,可以通过debug.PrintStack()打印出来。
  2. 如在程序中遇到一个Error,但是不期望程序panic,只是想把堆栈信息打印出来以便跟踪调试,可以使用debug.PrintStack()。

也可以读取堆栈信息自己处理和打印:

func DumpStacks() {
	buf := make([]byte, 16384)
	buf = buf[:runtime.Stack(buf, true)]
	fmt.Printf("=== BEGIN goroutine stack dump ===\n%s\n=== END goroutine stack dump ===", buf)
}

利用堆栈信息还可以获取goroutine的id:

func GoID() int {
	var buf [64]byte
	n := runtime.Stack(buf[:], false)
	idField := strings.Fields(strings.TrimPrefix(string(buf[:n]), "goroutine "))[0]
	id, err := strconv.Atoi(idField)
	if err != nil {
		panic(fmt.Sprintf("cannot get goroutine id: %v", err))
	}
	return id
}

协程相关

runtime.NumCPU()

获取CPU数量

runtime.GOMAXPROCS()

使用runtime.GOMAXPROCS()函数设置使用CPU核数

逻辑CPU数量描述
<1不修改任何数值
=1单核执行
>1多核并发执行

runtime.Gosched()

runtime.Gosched()用于将当前的goroutine让出CPU时间片,让其它的goroutine获得执行机会。同时,当前的goroutine会在未来某个时间点继续运行。

参考文献:

  • [1] wohu1104Go、运行时(go runtime)的含义
  • [2] ase2014、golang runtime Caller、Callers、CallersFrames、FuncForPC、Stack作用
  • [3] 腾讯技术工程​、万字长文深入浅出 Golang Runtime

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/190061.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

day15 二叉树 | 104、二叉树的最大深度 111、二叉树的最小深度 222、完全二叉树的节点个数

题目 104、二叉树的最大深度 递归法&#xff08;后序&#xff09;&#xff08;必须会&#xff09; // 定义&#xff1a;输入根节点&#xff0c;返回这棵二叉树的最大深度 int maxDepth(TreeNode root) {if (root null) {return 0;}// 利用定义&#xff0c;计算左右子树的最大…

论文笔记:Graph WaveNet for Deep Spatial-Temporal Graph Modeling

IJCAI 2019 1 abstract & intro 时空数据挖掘问题大多数使用邻接矩阵来建模节点之间的属性关系&#xff0c;这种思路的一个基本假设是&#xff1a;节点信息取决于自身和邻居的历史信息。 但这类模型的假设存在着一些问题&#xff1a; 未能充分建模节点之间的依赖关…

宝塔部署springboot,vue,node.js项目

宝塔部署springboot项目&#xff1a; 先将命令转移到jar包所属文件夹中 分为短暂部署和永久部署 短暂部署&#xff1a;java -jar xxx.jar 永久部署&#xff1a;nohup java -jar demo-1.0.0.jar logs_mark.txt 2>&1 & nohup:linux的命令,代表关闭但持续运行 查看898…

52.Isaac教程--操纵杆

操纵杆 ISAAC教程合集地址: https://blog.csdn.net/kunhe0512/category_12163211.html 文章目录操纵杆使用游戏机操纵杆使用其他操纵杆使用 Playstation 操纵杆很容易控制运行 Isaac SDK 的机器人&#xff0c;但也可以使用其他控制器。 使用游戏机操纵杆 按照以下步骤校准您的…

微信小程序018小说在线阅读系统书城

管理员的主要功能有&#xff1a; 1.管理员输入账户登陆后台 2.个人中心&#xff1a;管理员修改密码和账户信息 3.用户管理&#xff1a;对注册的用户信息进行删除&#xff0c;查询&#xff0c;添加&#xff0c;修改 4.小说信息管理&#xff1a;对小说信息进行添加&#xff0c;修…

TCP/IP第六章笔记ICMP协议

文章目录6.1 引言6.2 ICMP报文分组格式和类型6.3 ICMP地址掩码请求与应答6.4 ICMP时间戳请求与应答6.5 ICMP端口不可达差错6.6 ICMP的处理&#xff08;4.4BSD系统下&#xff09;6.1 引言 第三章在IP选择路由时&#xff0c;如果一个报文最后限制转发次数用完后还传输不到目的地…

【高并发】- 不可不知道的RPC框架服务通信

前言 前面章节讲解了高并发系统中相关指标、为什么要学习高并发设计思想、高并发系统中每个环节的流量处理等思想。本章节讲解服务通信&#xff0c;来帮助大家更好理解系统间通信过程。 1 RPC框架介绍 RPC&#xff08;Remote Procedure Call&#xff0c;远程过程调用&#xff0…

Win10家庭版和Win10专业版有什么区别?

win10操作系统拥有7个不同的版本&#xff0c;其中win10家庭版和专业版被人们广泛的应用&#xff0c;很多用户都不知道如何区分win10家庭版和专业版&#xff0c;接下来把win10家庭版和专业版有什么不同的地方告诉大家。我们一起来看看吧。 win10家庭版和专业版的区别&#xff1a…

java服务框架高级之微服务保护 Sentinel 限制规则,流控模式,流控效果

初识Sentinel 雪崩问题&#xff1a; 解决雪崩问题的常见方式有四种&#xff1a; 1.超时处理&#xff1a;设定超时时间&#xff0c;请求超过一定时间没有响应就返回错误信息&#xff0c;不会无休止等待 2.舱壁模式&#xff1a;限定每个业务能使用的线程数&#xff0c;避免耗尽…

2023外企还香吗?2022届计算机谈谈入职外企的感受和经历

互联网寒冬&#xff0c;大规模“毕业”的环境下&#xff0c;2023年外企又香了吗&#xff1f; 大家好&#xff0c;我是2022届计算机应届毕业生&#xff0c;毕业入职了一家大型非互联网外企&#xff0c;2022年由于只上了半年班&#xff0c;所以只有半年工资&#xff0c;总收入在1…

【JavaScript速成之路】一文带你初识JavaScript

&#x1f4c3;个人主页&#xff1a;「小杨」的csdn博客 &#x1f525;系列专栏&#xff1a;【JavaScript速成之路】 &#x1f433;希望大家多多支持&#x1f970;一起进步呀&#xff01; 文章目录前言1&#xff0c;JavaScript1.1&#xff0c;JavaScript概述1.2&#xff0c;Java…

【人工智能学习笔记】人工智能里的数学1——概述

与软件开发相比&#xff0c;人工智能领域需要大量数学知识。主要涉及微积分、线性代数、概率论和最优化。本文主要介绍人工智能里用到了哪些数学知识&#xff0c;试图向您提供一个目录式的、导读式的概述。后期计划一一展开讲解。本文作为我学习人工智能的笔记&#xff0c;主要…

C++继承(上)

我们知道&#xff0c;面向对象有三大特性&#xff1a;封装&#xff0c;继承&#xff0c;多态。封装前面已经说过&#xff0c;这篇文章主要说说继承。 文章目录1.继承的概念及定义1.1继承的概念1.2 继承定义1.2.1定义格式1.2.2继承关系和访问限定符2. 基类和派生类对象赋值转换…

vue.js客服系统实时聊天项目开发(十四)点击加载展示历史消息列表

当访客一进去聊天界面以后&#xff0c;需要获取一下历史消息展示到界面&#xff0c;并且需要能分页的原理展示 在顶部有一个加载更多记录的按钮&#xff0c;点击就能按分页获取数据 //展示历史消息记录getHistoryList(){var _thisthis;let pagesize5;this.$axios.get(this.ApiH…

Python | 数据类型之列表

知识目录一、定义和遍历1.1 定义列表1.2 打印和截取列表1.3 遍历列表二、增删改查2.1 更新和删除列表2.3 脚本操作符 * in三、函数和方法3.1 函数3.2 方法列表是最常用的Python数据类型&#xff0c;它可以作为一个方括号内的逗号分隔值出现。列表的数据项不需要具有相同的类型…

springboot-rocketmq整合NOT_CONSUME_YET问题处理

一、测试流程1.添加POM<dependency><groupId>org.apache.rocketmq</groupId><artifactId>rocketmq-spring-boot-starter</artifactId><version>2.2.1</version></dependency>2.配置属性参数# 默认的消息组 rocketmq.producer.…

微信小程序项目初试总结

微信小程序项目初试总结准备工作注册小程序账号获取AppID下载 微信开发者工具下载 HBuilderX安装 scss/sass 编译HBuilderX 的调试新建项目把项目运行到微信开发者工具使用 Git 管理项目把项目托管到码云模块制作通用tabBar首页分类搜索商品列表商品详情加入购物车购物车页面登…

【手把手教你C#如何使用SqlSugar操作MySQL数据库】三 SqlSugar使用案例

SqlSugar 连接数据库、创建数据表、增删改查用法1.SqlSugar 连接MySQL数据库1.创建数据库2.创建库中的数据表3.数据的插入4.数据的查询5.数据更新6.数据保存7.数据删除2.整体案例脚本代码1.SqlSugar 连接MySQL数据库 1.创建数据库 using SqlSugar; public class DB : Singlet…

Word数据恢复,简单几个方法恢复未保存的Word文档!

日常生活中&#xff0c;我们经常会用到Word文档&#xff0c;里面记录着我们很多重要内容。当遇到电脑死机、没电关机&#xff0c;或者是编辑文档的软件突然崩溃&#xff0c;我们又没有及时保存Word文档里面的数据&#xff0c;这时该怎么办&#xff1f;Word数据恢复&#xff0c;…

[LeetCode]2319. 判断矩阵是否是一个 X 矩阵

如果一个正方形矩阵满足下述 全部 条件&#xff0c;则称之为一个 X 矩阵 &#xff1a; 矩阵对角线上的所有元素都 不是 0矩阵中所有其他元素都是 0 给你一个大小为 n x n 的二维整数数组 grid &#xff0c;表示一个正方形矩阵。如果 grid 是一个 X 矩阵 &#xff0c;返回 true…