成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Go 官方錯誤處理討論:用 ? 替代 if err != nil 可以不?

開發 前端
今天我們給大家帶來了 Go 核心團隊的錯誤處理新提案,老大哥 @Ian Lance Taylor 基于 Rust 的問號操作符作為靈感,設計出了 Go 的問號操作符和塊的聯動機制。

大家好,我是煎魚。

對于 Go 這一門編程語言,截至目前較大爭議話題仍在 if err != nil 在 Go 應用里所帶來的各種繁雜代碼,引起了社區很多正反方的探討。

原本以為 Go 核心團隊已經擺爛了。但最近老大哥 @Ian Lance Taylor 提出了一個新提案[1](后轉為討論[2]),引起了大量的社區交流:

圖片圖片

背景:為什么還要關注這件事?

在 Go 核心團隊的視野中,現階段對于處理 Go 錯誤處理的動力,個人理解至少來源于以下幾個主要原因,不斷地推動他們看到這件事。

第一是:社區中用代碼反饋最多的,也就是在現在的 Go 應用代碼中,存在較多的 if err != nil 的相關代碼:

func CopyFile(src, dst string) error {
 r, err := os.Open(src)
 if err != nil {
  return err
 }
 defer r.Close()

 w, err := os.Create(dst)
 if err != nil {
  return err
 }
 defer w.Close()

 if _, err := io.Copy(w, r); err != nil {
  return err
 }
 if err := w.Close(); err != nil {
  return err
 }
}

一堆的 if err != nil 代碼。

第二是:在歷年的 Go 開發人員調查報告中提示 “錯誤處理被列為人們今天使用的最大特定挑戰”。

如下圖所示:

圖片圖片

在調查結果中,有提到:“在封閉問題中,回答最多的是學習如何有效地編寫 Go(15%)和錯誤處理的冗長(13%)。”

第三是:在 Go issues 中存在大量的 Go 錯誤處理的各類提案,例如:

圖片圖片

  • 《proposal: Go 2: onerr return[3]》
  • 《proposal: Go 2: add or err: statement after function calls for error handling[4]》
  • 《proposal: Go 2: Use ?variable simplify handling of multiple-return-values[5]》

太多太多太多這類提案了。我也分享過很多腦洞很大的社區錯誤新提案。

新提案:? 新語法

這種新語法的部分靈感來源于:Rust 的問號運算符。

? 將會吸收函數返回的錯誤,并在錯誤不為 nil 時自動返回,這與之前的 try 的提議類似。

它的不同之處在于:? 是一個顯式語法元素,而不是對預先聲明函數的調用,而且 ? 只能出現在語句的末尾,不能出現在表達式的中間。

基本介紹

例如,原本的 Go 錯誤處理代碼如下:

r, err := SomeFunction()
 if err != nil {
  return fmt.Errorf("something failed: %v", err)
 }

新提案引入新的 ? 語法,將其改寫為如下:

r := SomeFunction() ? {
  return fmt.Errorf("something failed: %v", err)
 }

當然。如果是另外一種原本的寫法:

if err := SomeFunction2(); err != nil {
  return fmt.Errorf("something else failed: %v", err)
 }

也依然可以改寫為:

SomeFunction2() ? {
  return fmt.Errorf("something else failed: %v", err)
 }

? 這個用法將會吸收函數的錯誤結果。它引入了一個新塊,如果錯誤結果不為 nil,則執行該塊塊。

在新塊中,fmt.Errorf 里的標識符 err 指的是上述吸收的錯誤結果。也就是當塊跟在 ? 后面時,它會隱式聲明一個新的 err 變量。

完整例子

func Run() error {
 Start() ? // returns error from Start if not nil
 Wait() ?  // returns error from Wait if not nil
 return nil
}
func CopyFile(src, dst string) error {
 r := os.Open(src) ? {
  return fmt.Errorf("copy %s %s: %v", src, dst, err)
 }
 defer r.Close()

 w := os.Create(dst) ? {
  return fmt.Errorf("copy %s %s: %v", src, dst, err)
 }

 io.Copy(w, r) ? {
  w.Close()
  os.Remove(dst)
  return fmt.Errorf("copy %s %s: %v", src, dst, err)
 }

 w.Close() ? {
  os.Remove(dst)
  return fmt.Errorf("copy %s %s: %v", src, dst, err)
 }
}
func MustOpen(n string) *os.File {
 f := os.Open(n) ? {
  panic(err)
 }
 return f
}
func TestFileData(t *testing.T) {
 f := os.Open("testfile") ? {
  t.Fatal(err)
 }
 ...
}
func CreateIfNotExist(name string) error {
 f, err := os.OpenFile(name, os.O_EXCL|os.O_WRONLY, 0o666)
 if errors.Is(err, fs.ErrExist) {
  return nil
 }
 err ? // returns err if it is not nil
 // write to f ...
}

社區爭論

Go 錯誤處理機制這事,一向是正反雙方都有。有支持繼續保持的,也有反對的。

其中一位社區同學 @Michael Fridman 直接掏出了 Go 創始人 @Rob Pike 的演講 PPT 語錄:

圖片

該位同學表示:這一提議的優點有限 -- 它增加了另一種做事的方式,并使代碼更難閱讀(具有諷刺意味的是)。

其真心希望谷歌不會不惜一切代價發展 Go 語言,因為這將損害 Go 的長期用戶對 Go 的喜愛。

并且表示:“讓我們保持 Go 的簡單和無趣”

總結

今天我們給大家帶來了 Go 核心團隊的錯誤處理新提案,老大哥 @Ian Lance Taylor 基于 Rust 的問號操作符作為靈感,設計出了 Go 的問號操作符和塊的聯動機制。

關于 Go 的錯誤處理機制,我經歷很多。見到各種人做封裝,還有使用 pnaic+recover 來做 error 機制的。各種方法都有。誰都不服誰。

但是目前 Go1 還是陷入了一個非常尷尬的境地,有人希望改,有人不希望改。無論如何都難以 “討好” 全部人。

接下來就看新上任的 Go 核心團隊負責人的魄力如何了。能否像以前 rsc 力推 module 一樣背負罵名且用力推進。

畢竟,@Ian Lance Taylor 能提出這個提案和討論。很有可能就是內部先討論過的了。

參考資料

[1]提案: https://github.com/golang/go/issues/71203

[2]討論: https://github.com/golang/go/discussions/71460

[3]proposal: Go 2: onerr return: https://github.com/golang/go/issues/32848

[4]proposal: Go 2: add or err: statement after function calls for error handling: https://github.com/golang/go/issues/33029

[5]proposal: Go 2: Use ?variable simplify handling of multiple-return-values: https://github.com/golang/go/issues/33074

責任編輯:武曉燕 來源: 腦子進煎魚了
相關推薦

2020-12-17 06:25:05

Gopanic 模式

2024-06-05 08:47:20

Go語言方式

2023-03-10 08:48:29

2014-11-17 10:05:12

Go語言

2021-04-29 09:02:44

語言Go 處理

2022-07-13 08:53:28

函數Go語言

2022-08-01 08:48:39

Go代碼接口

2025-06-05 02:25:00

2024-02-28 08:54:57

switchGo錯誤

2022-05-26 08:53:47

Go函數代碼

2024-03-14 09:35:54

Go 錯誤select代碼

2025-06-06 06:45:54

2022-06-13 07:03:25

Go 語言怎么優化重

2021-09-13 07:53:31

Go錯誤處理

2025-03-31 00:29:44

2022-09-05 08:55:15

Go2提案語法

2024-03-27 08:18:02

Spring映射HTML

2025-03-31 08:57:25

Go程序性能

2021-09-27 15:33:48

Go 開發技術

2023-10-26 15:49:53

Go日志
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品乱码久久久久v最新版 | 99久久免费精品国产男女高不卡 | 美女在线观看国产 | 91精品国产综合久久精品 | 综合成人在线 | 国产精品久久久久av | 亚洲成人午夜电影 | 在线不卡视频 | 草草影院ccyy | 视频在线一区二区 | 精品视频一区在线 | 国产成人aⅴ | 成人国产在线视频 | 亚洲国产午夜 | 99精品99| 欧美在线a | 老牛嫩草一区二区三区av | 成人在线视频网站 | www.99热.com| 成人不卡在线 | 性一交一乱一透一a级 | 精品久久久久久久久久久久 | 国产精品福利视频 | 久久99精品久久久久久琪琪 | 亚洲欧美国产毛片在线 | 最新中文字幕在线播放 | 日韩在线一区二区三区 | 一级片视频免费观看 | 久久久久国产精品午夜一区 | 成人av高清| 韩国欧洲一级毛片 | 九九热在线精品视频 | 欧美一级免费黄色片 | 久久久国产精品视频 | 精品三级在线观看 | 国产精品福利久久久 | 欧美精品一区二区三区在线四季 | 欧美一级黄色免费看 | 国产精品久久久久久妇女 | 国产精品久久久久久久久久妇女 | 久久不卡 |