> 백엔드 개발 > Golang > Go에서 현재 함수 이름을 어떻게 얻을 수 있나요?

Go에서 현재 함수 이름을 어떻게 얻을 수 있나요?

Patricia Arquette
풀어 주다: 2024-12-30 13:02:13
원래의
173명이 탐색했습니다.

How Can I Get the Current Function Name in Go?

Go에서 현재 함수 이름 얻기

Go 프로그램의 실행 흐름을 추적하기 위해, 현재 함수 이름. 이는 디버깅이나 로깅 목적에 유용할 수 있습니다.

Go에서 현재 함수 이름을 얻으려면 프로그램 카운터(PC)를 인수로 사용하고 해당 함수를 반환하는 Runtime.FuncForPC 함수를 사용할 수 있습니다. 물체. 이것이 어떻게 사용될 수 있는지에 대한 예는 다음과 같습니다.

package main

import (
    "fmt"
    "runtime"
)

func trace() {
    pc := make([]uintptr, 10)  // at least 1 entry needed
    runtime.Callers(2, pc)
    f := runtime.FuncForPC(pc[0])
    file, line := f.FileLine(pc[0])
    fmt.Printf("%s:%d %s\n", file, line, f.Name())
}

func main() {
    trace()
}
로그인 후 복사

이 프로그램이 실행되면 다음 출력이 인쇄됩니다.

/path/to/file.go:13 trace
로그인 후 복사

이 출력은 추적 기능이 온라인에서 호출되었음을 나타냅니다. 13 파일 file.go.

참고: Go 버전 1.7 이상에서는 대신 런타임.CallersFrames를 사용하는 것이 좋습니다. 런타임.FuncForPC. Runtime.CallersFrames를 사용하여 업데이트된 예는 다음과 같습니다.

package main

import (
    "fmt"
    "runtime"
)

func trace() {
    pcs := make([]uintptr, 10)
    n := runtime.CallersFrames(2, pcs)
    frames := runtime.CallersFrames(n)
    frame, _ := frames.Next()
    fmt.Printf("%s:%d %s\n", frame.File, frame.Line, frame.Function)
}

func main() {
    trace()
}
로그인 후 복사

위 내용은 Go에서 현재 함수 이름을 어떻게 얻을 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿