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