在阅读gorm时看到的,记录一下
// 这里的正则需要修改成自己的
var goSrcRegexp = regexp.MustCompile(`gopkg/gorm/.*.go`)
var goTestRegexp = regexp.MustCompile(`gopkg/gorm/.*test.go`)
func fileWithLineNum() string {
for i := 2; i < 15; i++ {
_, file, line, ok := runtime.Caller(i)
if ok && (!goSrcRegexp.MatchString(file) || goTestRegexp.MatchString(file)) {
return fmt.Sprintf("%v:%v", file, line)
}
}
return ""
}
在研究gorm库的过程中,了解到如何在Go语言中实现在运行时获取当前代码执行的行数,这一特性对于调试和日志记录非常有用。
716

被折叠的 条评论
为什么被折叠?



