golang: 返回错误时打印堆栈

一,默认的错误打印:

1,定义函数:

//打印错误的堆栈信息
func PrintStackTrace(err error) {
	// 创建一个缓冲区用于存储堆栈信息
	buf := bytes.NewBuffer(nil)

	// 获取当前goroutine的堆栈信息
	for i := 0; ; i++ {
		pc, file, line, ok := runtime.Caller(i)
		if !ok {
			break
		}
		fmt.Fprintf(buf, "%d: %s:%d (0x%x)\n", i, file, line, pc)
	}

	// 打印堆栈信息
	fmt.Println(buf.String())
}

 

2,调用定义的方法

	fields := []string{"id", "addtime","abcd"}

	var rows *sql.Rows
	var err error
	rows,err = config.DBLink.Select(fields).Table(model.PlModel{}.TableName()).Where("uid=? and status=1",uid).Order("id desc").Offset(offset).Limit(size).Rows()

	if err != nil {
		fmt.Println("错误信息:",err)
		fmt.Println("堆栈:")
		config.PrintStackTrace(err)
	}

 

二,测试效果:


错误信息: Error 1054 (42S22): Unknown column 'abcd' in 'field list'
堆栈:
0: /data/test/config/globalFunction.go:101 (0x9aecd9)
1: /data/test/service/PlService.go:41 (0x9df044)
2: /data/test/controller/userController.go:362 (0xa569f4)
3: /data/gopath/pkg/mod/github.com/gofiber/fiber/v2@v2.52.5/router.go:145 (0x9a639d)
4: /data/gopath/pkg/mod/github.com/gofiber/fiber/v2@v2.52.5/ctx.go:1034 (0x99002c)
5: /data/gopath/pkg/mod/github.com/gofiber/fiber/v2@v2.52.5/router.go:425 (0x9a7fd0)
6: /data/gopath/pkg/mod/github.com/gofiber/fiber/v2@v2.52.5/ctx.go:1031 (0x99001c)
7: /data/gopath/pkg/mod/github.com/gofiber/fiber/v2@v2.52.5/middleware/recover/recover.go:43 (0xa5a0fa)
8: /data/gopath/pkg/mod/github.com/gofiber/fiber/v2@v2.52.5/router.go:145 (0x9a639d)
9: /data/gopath/pkg/mod/github.com/gofiber/fiber/v2@v2.52.5/router.go:172 (0x9a65c8)
10: /data/gopath/pkg/mod/github.com/valyala/fasthttp@v1.57.0/server.go:2385 (0x960dd0)
11: /data/gopath/pkg/mod/github.com/valyala/fasthttp@v1.57.0/workerpool.go:225 (0x96c9f1)
12: /data/gopath/pkg/mod/github.com/valyala/fasthttp@v1.57.0/workerpool.go:197 (0x96c791)
13: /usr/local/soft/go/src/runtime/asm_amd64.s:1700 (0x478160)

 

posted @ 2024-12-07 12:32  刘宏缔的架构森林  阅读(48)  评论(0编辑  收藏  举报