目錄
- 前言
- 能不能 try catch
- 加入處理異常方法
- 總結
前言
Golang語言有諸多優點:靜態編譯、協程、堪比c語言的高性能。
但是也有一些令人發指的地方 —— 經常被人調侃 五行代碼,三行錯誤處理 的異常錯誤處理方式,如下問題出現的地方
func readFile(path string) ([]byte, error) {
file, err := os.Open(path)
if err != nil {
return nil, err
}
defer file.Close()
return ioutil.ReadAll(file)
}
函數readFile的功能是讀出指定文件本身的內容并將其返回,同時當有錯誤發生時立即向調用方報告。
根據Golang編程范式,每個可能導致錯誤的函數都應該將error作為最后一個返回值,所以Golang代碼中隨處都是"if err != nil"語句。 五行代碼,三行錯誤處理 的調侃段子由此在圈內流行
能不能 try catch
我之前常用編程語言 Python 和 PHP 的時候,早已經習慣 try catch 處理異常的方式。于是對 Golang 使用流程控制 配合 panic()、recover() 一直耿耿于懷,為了以后舒服今天就來實現一下原來 try catch異常錯誤處理方式
Golang 語言中擁有 recover() 函數作為宕機恢復機制,讓程序在宕機流程中的 goroutine 中恢復。
所以我們能夠用 recover() 函數作為程序中是否出現的鉤子。當出現異常時,由它調起我們的異常處理函數。首先簡單實現一下:
package main
import "fmt"
func try(userFn func()) {
defer func() {
if err := recover();err != nil{
fmt.Printf("程序執行發生異常: %v\n", err)
}
}()
userFn()
}
func foo(num int) {
if num 10 {
panic("number is less than 10")
}else {
panic("number is greater than 10")
}
}
func main() {
try(func() {
foo(9)
})
try(func() {
foo(11)
})
}
go run main.go 運行:
$ go run _test/demo3/test3.go
程序執行發生異常: number is less than 10
程序執行發生異常: number is greater than 10
從上可以看出,recover() 函數完成我們讓它作為鉤子,的作用,調起了打印 程序執行發生異常 的信息。
加入處理異常方法
捕抓到異常還需要處理異常,而不是簡單打印 程序執行發生異常。所以還需要增加匿名方法作為異常處理方法,改造如下:
func try(userFn func(), catchFn func(err interface{})) {
defer func() {
if err := recover();err != nil{
catchFn(err)
}
}()
userFn()
}
...
func main() {
try(func() {
foo(9)
}, func(err interface{}) {
fmt.Printf("程序執行發生異常: %v\n", err)
})
try(func() {
foo(11)
}, func(err interface{}) {
fmt.Printf("程序執行發生異常: %v\n", err)
})
}
這樣就可以隨心所欲傳入自定義處理異常的方法
總結
以上只是自己簡單實現了try catch,其中還有很多缺陷,比如:不支持 finally 函數處理,try catch封裝過于簡單。
到此這篇關于試了下Golang實現try catch的方法的文章就介紹到這了,更多相關Golang try catch內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- 利用golang實現封裝trycatch異常處理實例代碼
- Golang try catch與錯誤處理的實現