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 중국어 웹사이트의 기타 관련 기사를 참조하세요!