golang直接获取当前函数名称


// 获取正在运行的函数名
func runFuncName()string{
	pc := make([]uintptr,1)
	runtime.Callers(2,pc)
	f := runtime.FuncForPC(pc[0])
	return f.Name()
}

使用方法

package main

import(
	"fmt"
	"runtime"
)

// 获取正在运行的函数名
func runFuncName()string{
	pc := make([]uintptr,1)
	runtime.Callers(2,pc)
	f := runtime.FuncForPC(pc[0])
	return f.Name()
}

func test1(){
	i:=0
	fmt.Println("i =",i)
	fmt.Println("FuncName1 =",runFuncName())
}

func test2(){
	i:=1
	fmt.Println("i =",i)
	fmt.Println("FuncName2 =",runFuncName())
}

func main(){
	fmt.Println("打印运行中的函数名")
	test1()
	test2()
}


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM