在 Go 中,當處理大量潛在錯誤時,錯誤處理可能會變得乏味。例如,考慮以下程式碼:
aJson, err1 := json.Marshal(a) bJson, err2 := json.Marshal(b) cJson, err3 := json.Marshal(c) dJson, err4 := json.Marshal(d) eJson, err5 := json.Marshal(e) fJson, err6 := json.Marshal(f) gJson, err4 := json.Marshal(g) if err1 != nil { return err1 } else if err2 != nil { return err2 } else if err3 != nil { return err3 } else if err4 != nil { return err4 } else if err5 != nil { return err5 } else if err5 != nil { return err5 } else if err6 != nil { return err6 }
此程式碼的錯誤處理高度重複且難以維護。一種更乾淨、更有效率的方法是使用閉包一次處理所有錯誤:
var err error f := func(dest *D, src S) bool { *dest, err = json.Marshal(src) return err == nil } // EDIT: removed () f(&aJson, a) && f(&bJson, b) && f(&cJson, c) && f(&dJson, d) && f(&eJson, e) && f(&fJson, f) && f(&gJson, g) return err
這個函數指標f 封裝了錯誤處理邏輯,並透過連結呼叫並傳回第一個非函數來簡化主函數。 -nil 遇到錯誤。透過實作這種技術,您可以實現更簡潔、更優雅的錯誤處理。
以上是如何在 Go 中優雅地處理多個錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!