NewOption自定义配置的错误对象创建

  • 说明:用于自定义配置的错误对象创建。
  • 格式:

    1. NewOption(option Option) error
  • 示例:

    1. func ExampleNewOption() {
    2. err := gerror.NewOption(gerror.Option{
    3. Text: "this feature is disabled in this storage",
    4. Code: gcode.CodeNotSupported,
    5. })
    6. }

fmt 格式化

通过以上示例我们可以看到,通过%+v的打印格式可以打印出完整的堆栈信息,当然gerror.Error对象支持多种fmt格式:

格式符输出内容
%v, %s打印所有的层级错误信息,构成完成的字符串返回,多个层级使用:拼接。
%-v, %-s打印当前层级的错误信息,返回字符串。
%+s打印完整的堆栈信息列表。
%+v打印所有的层级错误信息字符串,以及完整的堆栈信息,等同于%s\n%+s

使用示例:

  1. package main
  2. import (
  3. "errors"
  4. "fmt"
  5. "github.com/gogf/gf/v2/errors/gerror"
  6. )
  7. func main() {
  8. var err error
  9. err = errors.New("sql error")
  10. err = gerror.Wrap(err, "adding failed")
  11. err = gerror.Wrap(err, "api calling failed")
  12. fmt.Printf(" %%s: %s\n", err)
  13. fmt.Printf("%%-s: %-s\n", err)
  14. fmt.Println("%+s: ")
  15. fmt.Printf("%+s\n", err)
  16. }
  17. // Output:
  18. // %s: api calling failed: adding failed: sql error
  19. // %-s: api calling failed
  20. // %+s:
  21. // 1. api calling failed
  22. // 1). main.main
  23. // /Users/john/Workspace/Go/GOPATH/src/github.com/gogf/gf/.example/other/test.go:14
  24. // 2. adding failed
  25. // 1). main.main
  26. // /Users/john/Workspace/Go/GOPATH/src/github.com/gogf/gf/.example/other/test.go:13
  27. // 3. sql error

日志输出支持

glog日志管理模块天然支持对gerror错误堆栈打印支持,这种支持不是强耦合性的,而是通过fmt格式化打印接口支持的。

使用示例:

  1. package main
  2. import (
  3. "errors"
  4. "github.com/gogf/gf/v2/frame/g"
  5. "github.com/gogf/gf/v2/errors/gerror"
  6. )
  7. func main() {
  8. var err error
  9. err = errors.New("sql error")
  10. err = gerror.Wrap(err, "adding failed")
  11. err = gerror.Wrap(err, "api calling failed")
  12. g.Log().Printf("%+v", err)
  13. }
  14. // Output:
  15. // 2020-10-17 15:22:26.793 api calling failed: adding failed: sql error
  16. // 1. api calling failed
  17. // 1). main.main
  18. // /Users/john/Workspace/Go/GOPATH/src/github.com/gogf/gf/.example/other/test.go:14
  19. // 2. adding failed
  20. // 1). main.main
  21. // /Users/john/Workspace/Go/GOPATH/src/github.com/gogf/gf/.example/other/test.go:13
  22. // 3. sql error