Go打印行号和文件名

runtime.Caller

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

Caller报告当前go程调用栈所执行的函数的文件和行号信息。实参skip为上溯的栈帧数,0表示Caller的调用者(Caller所在的调用栈)。函数的返回值为调用栈标识符、带路径的完整文件名、该调用在文件中的行号。如果无法获得信息,ok会被设为false。

这里的skip指的是跳过多少个函数栈:

skip == 0,不跳过函数栈,返回当前函数PC,文件名,所在行
skip == 1,跳过当前函数栈,返回上层调用者调用当前函数时的PC,文件名,所在行
skip == 2,以此类推

根据pc获取函数名

根据返回的调用栈标识符pc,我们可以获取对应的函数名。
需要用到一个函数和一个方法,签名如下:

func FuncForPC(pc uintptr) *Funcfunc (*Func) Name

FuncForPC返回一个表示调用栈标识符pc对应的调用栈的*Func;如果该调用栈标识符没有对应的调用栈,函数会返回nil。每一个调用栈必然是对某个函数的调用。
Name返回该调用栈所调用的函数的名字。
实例

package mainimport ("fmt""path""runtime"
)func getInfo(skip int) (funcName, fileName string, lineNo int) {pc, file, lineNo, ok := runtime.Caller(skip)if !ok {fmt.Println("runtime.Caller() failed")return}funcName = runtime.FuncForPC(pc).Name()fileName = path.Base(file) // Base函数返回路径的最后一个元素return
}func main() {fmt.Println(getInfo(0))fmt.Println(getInfo(1))
}

输出

main.getInfo main.go 10
main.main main.go 22

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

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

相关文章

独家精品!git action发布electron成功的关键

首先来说git action真心是个坑爹货,使用起来太费劲了,各种报错一大堆。 再加上electron这个更坑爹的东西,二者合璧要把你累死一层皮。 昨天经过反复测试,通过无数次的失败,查找,试验,再失败&a…

函数调用的形式写一个动态监控secure日志文件的sh脚本、过滤出secure日志异常用户名的ip并用iptables限制

文章目录 脚本说明脚本代码测试secure日志secure监测测试代码执行检测脚本验证上线代码放到定时任务中执行验证脚本说明 实现功能如下: 1、记录secure日志文件中登录失败的IP和其失败的次数2、记录secure日志文件中登录失败的IP并以数组的形式输出【因为iptables规则必须一次识…

在Linux中对Docker中的服务设置自启动

先在Linux中安装docker,然后对docker中的服务设置自启动。 安装docker 第一步,卸载旧版本docker。 若系统中已安装旧版本docker,则需要卸载旧版本docker以及与旧版本docker相关的依赖项。 命令:yum -y remove docker docker-c…

封装一个基于ThreeJS渲染基础模型的类,非常简单,可拖动可缩放

工作需求要求threeJS渲染一个模型以供可视化大屏展示,抛出模型精度不谈,只说业务实现 1.Three.JS的引入 ThreeJS官网地址:Three.js – JavaScript 3D Library 查看文档 中文切换及安装创建步骤 如果是自己研究学习用的,在官网安装完后&…

Linux配置路由功能及添加静态路由

一、配置路由功能 Linux作为路由器,Linux本身就具备路由功能,开启方式如下: 临时开启: echo "1" > /proc/sys/net/ipv4/ip_forward永久开启: vim /etc/sysctl.confnet.ipv4.ip_forward1 # 配置生效 sys…

linux的基本指令

目录 ls指令: pwd指令: cd指令: touch指令: mkdir指令: rmdir指令: rm指令: man指令: mv指令: cat指令: more指令: less指令: head指…

Blazor Table 实现获取当前选中行的功能

这里需要使用到OnClickRowCallBack事件 后台使用案例

Qt递归遍历子控件的按钮并设置辉光(阴影)效果

#include "mainwindow.h"#include <QApplication> #include <QPushButton> #include <QGraphicsDropShadowEffect> #include <QVBoxLayout>void applyEffectToButtons(QWidget *widget, const QColor& color) {// 使用 findChildren 查找…

【Python】数据分析案例:世界杯数据可视化 | 文末送书

文章目录 前期数据准备导入数据 分析&#xff1a;世界杯中各队赢得的比赛数分析&#xff1a;先打或后打的比赛获胜次数分析&#xff1a;世界杯中的抛硬币决策分析&#xff1a;2022年T20世界杯的最高得分者分析&#xff1a;世界杯比赛最佳球员奖分析&#xff1a;最适合先击球或追…

全能音乐制作环境——水果编曲软件FL Studio 21.1版本下载安装配置

目录 前言一、FL Studio 安装二、使用配置总结 前言 FL Studio是一款流行的图像线软件制作和编辑音频文件。作为一款领先的创新产品&#xff0c;该软件能够满足在创作音乐方面的需求。有了这个产品&#xff0c;可以完成制作音乐的整个过程。可以使用这个软件进行写作&#xff…

YOLOv5实现目标分类计数并显示在图像上

有同学后台私信我&#xff0c;想用YOLOv5实现目标的分类计数&#xff0c;因此本文将在之前目标计数博客的基础上添加一些代码&#xff0c;实现分类计数。阅读本文前请先看那篇博客&#xff0c;链接如下&#xff1a; YOLOv5实现目标计数_Albert_yeager的博客 1. 分类实现 以co…

已解决ModuleNotFoundError: No module named ‘cv2‘

已解决ModuleNotFoundError: No module named ‘cv2’ 文章目录 报错问题解决思路解决方法交流 报错问题 ModuleNotFoundError: No module named ‘cv2‘ 解决思路 您遇到的错误"ModuleNotFoundError: No module named ‘cv2’"是因为您的 Python 环境中没有安装 O…

深入理解 Java Bean 的生命周期及各个阶段解析

目录 引言&#xff1a;一、什么是Java Bean二、Bean的生命周期概述三、Bean的创建阶段四、属性设置阶段初始化阶段六、使用阶段七、销毁阶段 引言&#xff1a; Java Bean是Java编程中经常使用的重要概念&#xff0c;它是可重用、可移植、可序列化的组件。在Java开发中&#xf…

最新的外贸自建站教程?做外贸如何建网站?

外贸自建站教程步骤有哪些&#xff1f;海洋建站如何做网站搭建&#xff1f; 想要了解关于外贸自建站的最新教程吗&#xff1f;外贸自建站不再是高不可攀的难题&#xff0c;相反&#xff0c;它为企业提供了更多的机会和自主掌握业务的空间。海洋建站将为您提供一份全面的指南&a…

[ TypeScript ] 多个不同文件但类型名相同该如何区分?

多个不同文件但类型名相同该如何区分&#xff1f; 问题描述 在 TypeScript 中&#xff0c;当我们在不同的文件中定义相同的类型名称时就会导致类型冲突&#xff0c;程序也不知道要使用哪个类型 // A.d.ts type ID number;// B.d.ts type ID string;// 使用 const a: ID 1…

Android 编译的配置文件:android.mk 和android.bp

Android.bp文件首先是Android系统的一种编译配置文件&#xff0c;是用来代替原来的Android.mk文件的。在Android7.0以前&#xff0c;Android都是使用make来组织各模块的编译&#xff0c;对应的编译配置文件就是Android.mk。在Android7.0开始&#xff0c;Google引入了ninja和kat…

什么是大数据测试?有哪些类型?应该怎么测?

随着目前世界上各个国家使用大数据应用程序或应用大数据技术场景的数量呈指数增长&#xff0c;相应的&#xff0c;对于测试大数据应用时所需的知识与大数据测试工程师的需求也在同步增加。 针对大数据测试的相关技术已慢慢成为当下软件测试人员需要了解和掌握的一门通用技术。…

万媒易发:以RPA自动化和AIGC为基础实现多平台分发

引言 在当今数字化时代&#xff0c;信息传播的速度越来越快&#xff0c;多平台分发成为了内容创作者们必须面对的重要挑战之一。为了解决这一难题&#xff0c;我们可以借助RPA&#xff08;Robotic Process Automation&#xff09;自动化和AIGC&#xff08;Artificial Intellig…

SPSS生存分析:寿命表分析

前言&#xff1a; 本专栏参考教材为《SPSS22.0从入门到精通》&#xff0c;由于软件版本原因&#xff0c;部分内容有所改变&#xff0c;为适应软件版本的变化&#xff0c;特此创作此专栏便于大家学习。本专栏使用软件为&#xff1a;SPSS25.0 本专栏所有的数据文件请点击此链接下…

Scala--1

package scala02object scala01_comment {def main(args: Array[String]): Unit {//// 单行注释/*多行注释*//*** 文档注释*/// 代码规范// 1.将代码格式化 ctrl alt lval a: Int 10// 2.代码不要写过长}}package scala02object scala_valANDVar {def main(args: Array[Strin…