Go打印行号和文件名

runtime.Caller

cpp 复制代码
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,我们可以获取对应的函数名。

需要用到一个函数和一个方法,签名如下:

cpp 复制代码
func FuncForPC(pc uintptr) *Func

func (*Func) Name

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

Name返回该调用栈所调用的函数的名字。
实例

cpp 复制代码
package main

import (
	"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))
}

输出

cpp 复制代码
main.getInfo main.go 10
main.main main.go 22
相关推荐
LiaCode10 小时前
Redis 在生产项目的使用
前端·后端
用户5598224812210 小时前
Docker Compose Down 导致容器数据误删——ext4 日志恢复全记录
后端
LiaCode10 小时前
一天学完 redis 的爽翻版核心知识总结
前端·后端
大刚测试开发实战10 小时前
如何内网穿透访问本地私有化部署的TestHub
前端·后端·github
xiaodaoluanzha10 小时前
迄今為止,最簡單的編程語言 Nolang
前端·后端
Csvn10 小时前
Docker 容器管理入门 — 从镜像到容器编排
后端
用户7623524259110 小时前
ShardingJDBC
后端
行者全栈架构师10 小时前
IDEA 中 Maven 项目的 15 个红色报错快速解决方法
java·后端
Colin草率地做慢慢地改10 小时前
关于QuickStore这个项目的重构(2)- 数据库建表文件
后端·面试·架构
IT_陈寒11 小时前
SpringBoot自动配置这个坑,我踩进去又爬出来了
前端·人工智能·后端