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()
}
posted @ 2019-10-26 22:56  Myuniverse  阅读(11248)  评论(1编辑  收藏  举报