golang 1.13 errors 包 新函数介绍

原创
2019/10/15 09:21
阅读数 706

这次 errors 包算重量级更新。很有更能把以前的一些设计模式给推到。下面聊下用法。

error 装包

以前返回一个错误,想要保存 error 链,还要定义结构体保存以前的 error 信息。感兴趣看下 syscal.ECONNREFUSED 如何封装到 url.Error 的。现在只要%w 就行

err = fmt.Errorf("第二层错误信息 %w", err)

error 解包

如果是 fmt.Errorf("%w", err) 定义的错误链可以通过,或者实现了Unwrap接口的错误

e = errors.Unwrap(e) //解包错误

装包解包需要注意的地方

装包和解包错误是一一对应的,一次 Unwrap 调用,解一次 fmt.Errorf("%w", err)调用

package main

import (
    "errors"
    "fmt"
)

func main() {

    var e, first error

    first = errors.New("head")

    e = fmt.Errorf("第一层错误:%w", first)
    e = fmt.Errorf("第二层错误:%w", e)
    e = fmt.Errorf("第三层错误:%w", e)
    e = fmt.Errorf("第四层错误:%w", e)

    //解包错误
    e = errors.Unwrap(e)
    fmt.Printf("%s\n", e)

    //解包错误
    e = errors.Unwrap(e)
    fmt.Printf("%s\n", e)

    //解包错误
    e = errors.Unwrap(e)
    fmt.Printf("%s\n", e)

    //解包错误
    e = errors.Unwrap(e)
    fmt.Printf("%s\n", e)
}

/*
第三层错误:第二层错误:第一层错误:head
第二层错误:第一层错误:head
第一层错误:head
head

*/

判断错误是否相等

过去写法 ==

if err == os.ErrNotExistF {

}

现在写法 errors.Is

以前只有一个错误,现在是错误链表,要通过 errors.Is 遍历判断

b := errors.Is(err, os.ErrNotExist)
fmt.Printf("%t\n", b)

新写法根据具体类型判断 errors.As

errors.As和errors.Is的区别,主要是取出这种类型的错误

 if _, err := os.Open("non-existing"); err != nil {
        var pathError *os.PathError
        if errors.As(err, &pathError) {
            fmt.Println("Failed at path:", pathError.Path)
        } else {
            fmt.Println(err)
        }
    }

交流学习

errors 包的一些姿势还要等长时间使用才能完全开发出来,欢迎 朋友提出想法,一起学习。

github

https://github.com/guonaihong/gout

展开阅读全文
Go
打赏
0
1 收藏
分享
加载中
errorsas是啥意思
2019/10/15 10:00
回复
举报
guonaihong博主
errors.As是error链里面取出 某个实现error接口的类型。 比如标准库http.Get(url)返回的错误,err 是个错误链,具体实现是 *url.Error 里面包了*net.OpError ,*net.OpError里面包了*os.SyscallError。 要从err取出os.SyscallError 。传统方式是,一个类型接着一个类型断言。go 1.13直接errors.As就行。可以理解为 从err query出这个类型。 ```go package main import ( "errors" "fmt" "net/http" "os" ) func main() { var e *os.SyscallError _, err := http.Get("http://127.0.0.1:3333") if errors.As(err, &e) { fmt.Printf("%s\n", e.Syscall) } } ```
2019/10/15 12:44
回复
举报
哦懂了意思就是不需要一层一层的来剥开错误。直接用这个函数来得到错误。谢了。。
2019/10/16 11:07
回复
举报
guonaihong博主
是的。。。😄
2019/10/16 19:09
回复
举报
更多评论
打赏
4 评论
1 收藏
0
分享
返回顶部
顶部