Go 語言提供了以下錯誤處理機制:直接處理錯誤:在函數體內檢查 err 變數。使用 defer:在函數退出時執行程式碼,無論函數是否返回正常或錯誤,用於清理資源或列印錯誤訊息。使用 recover:捕獲運行時恐慌,通常是由未處理的錯誤引起的。自訂類型和錯誤包裝:建立自訂錯誤類型並使用 errors.Is 和 errors.As 函數包裝其他錯誤,允許類型斷言。
Go 語言提供了強大的錯誤處理機制,讓開發人員以清晰、統一的方式處理錯誤。本文將介紹 Go 中錯誤處理的不同策略,並透過實戰案例進行示範。
在Go 中,錯誤值由error
介面表示,它只是一個實作了Error()
方法的類型。錯誤值通常透過 nil
或 errors.New()
函數來建立。以下是如何定義和傳回一個錯誤值:
func myFunction() error { return errors.New("error message") }
最簡單的方法是直接處理錯誤,方法是在函數體中檢查err
變數:
func main() { if err := myFunction(); err != nil { log.Println(err) } }
defer
defer
語句允許在函數退出時執行程式碼,無論該函數是否傳回正常或錯誤。這可以用於清理資源或列印錯誤訊息:
func main() { defer func() { if err := recover(); err != nil { log.Println(err) } }() myFunction() }
recover
#recover
函數可以捕捉執行時間恐慌,它通常是由未處理的錯誤引起的。可以透過在main
函數中呼叫recover
來處理未處理的錯誤:
func main() { if err := recover(); err != nil { log.Println(err) } myFunction() }
對於複雜場景,可以建立自訂錯誤類型並使用errors.Is
和errors.As
函數包裝其他錯誤。這允許在錯誤層次結構中進行類型斷言:
type MyError struct { error } func main() { if err := myFunction(); err != nil { if myError, ok := err.(MyError); ok { log.Println(myError) } else { log.Println(err) } } }
考慮一個需要連接到資料庫並執行查詢的應用程式。應用程式可以按照以下方式處理錯誤:
func main() { db, err := sql.Open("mysql", "user:password@tcp(127.0.0.1:3306)/database") if err != nil { log.Fatal(err) } defer db.Close() rows, err := db.Query("SELECT * FROM table") if err != nil { log.Println(err) return } defer rows.Close() for rows.Next() { var name string if err := rows.Scan(&name); err != nil { log.Println(err) continue } log.Println(name) } }
應用程式使用 defer
語句來確保在遇到錯誤時正確關閉資料庫和查詢句柄。它還使用直接錯誤處理來列印錯誤訊息並繼續處理,以避免因單一錯誤而中斷整個應用程式。
以上是Golang函數的錯誤處理策略的詳細內容。更多資訊請關注PHP中文網其他相關文章!