刷到一个比较骚的 Go 错误处理新提案。。。

大家好,我是煎鱼。

在比较一段长的时间里,Go 的错误处理已经没有什么特别的进展和新改进了。看着已经到了瓶颈期。

今天在 GitHub 上学习时,看到 Go 社区里有人提了个错误处理的优化提案《proposal: Go 2: Error-Handling Paradigm with !err Grammar Sugar[1]》,也是引入新的语法来解决该问题。

大家一起来看看,也集思广益一下。原提案作者的目的是新增一个 listen 关键字和配合管道符等语法来实现新的错误处理。

原本的 Go1 代码,我们在处理错误时需要使用 if err != nil。如下代码:

func copy(src, dst string) (int64, error) {
    r, err := os.Open("input.txt")
    if err != nil {
        return 0, err
    }
    defer r.Close()
 
    w, err := os.Create("output.txt")
    if err != nil {
        return 0, err
    }
    defer w.Close()
    
    if _, err = io.Copy(w, r); err != nil {
        return 0, err
    }
    return 0, err
}

本提案的变化是:新增一个 listen 关键字,用于监听 err 变量,再配合 "|" 管道符来实现新的错误处理机制。

如下演示代码:

listen: err {
    if err != nil  {
        return 0, err
    }
    return 0, nil
}()

func copy(src, dst string) (int64, error) {
    listen:
    
    r, err := os.Open("input.txt")
    defer r.Close()
 
    w, err := os.Create("output.txt")
    defer w.Close()

    _, err = io.Copy(w, r) 
}

listen 关键字监听了 err 变量,再在上述的代码块中进行统一的错误逻辑处理。

如果是多个 err 变量,会是如下处理方式:

listen: err | err2 {
    if err != nil  {
        return 0, err
    }
    return 0, nil
}()

增加了管道符,同时对 err 和 err2 变量进行监听和处理。

本提案还在等待作者补充更多的语言变更的实现细节。不过截至目前为止,吐槽是不少的。

大家对此有没有更好的建议和想法呢?

Go 的新错误处理的改造方向真的是让人头大。我这边有记载被 ban 的《错误处理合集》都已经有许多了。感觉停滞不前中。可能现在就是最好的?

推荐阅读

参考资料

[1]

proposal: Go 2: Error-Handling Paradigm with !err Grammar Sugar: https://github.com/golang/go/issues/63961

关注和加煎鱼微信,

一手消息和知识,拉你进技术交流群👇

18372b6806b8953edb8ff3c221b70eed.jpeg

17f6b557bfbb36d3b35863c42ebdc410.png

你好,我是煎鱼,出版过 Go 畅销书《Go 语言编程之旅》,再到获得 GOP(Go 领域最有观点专家)荣誉,点击蓝字查看我的出书之路

日常分享高质量文章,输出 Go 面试、工作经验、架构设计,加微信拉读者交流群,和大家交流!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值