Golang 有2個(gè)內(nèi)置的函數(shù) panic()
和 recover()
,用以報(bào)告和捕獲運(yùn)行時(shí)發(fā)生的程序錯(cuò)誤,與 error 不同,panic-recover 一般用在函數(shù)內(nèi)部。一定要注意不要濫用 panic-recover,可能會(huì)導(dǎo)致性能問(wèn)題,我一般只在未知輸入和不可靠請(qǐng)求時(shí)使用。
golang 的錯(cuò)誤處理流程:當(dāng)一個(gè)函數(shù)在執(zhí)行過(guò)程中出現(xiàn)了異常或遇到 panic()
,正常語(yǔ)句就會(huì)立即終止,然后執(zhí)行 defer 語(yǔ)句,再報(bào)告異常信息,最后退出 goroutine。如果在 defer 中使用了 recover() 函數(shù),則會(huì)捕獲錯(cuò)誤信息,使該錯(cuò)誤信息終止報(bào)告。
看代碼:
package main
import "fmt"
func main(){
defer func(){
fmt.Println("c")
// if err := recover(); err != nil{
// fmt.Println(err)
// }else{
// fmt.Println("hehe")
// }
// if err := recover(); err != nil{
// fmt.Println(err)
// }else{
// fmt.Println("haha")
// }
fmt.Println("d")
}()
f()
defer func(){
fmt.Println("e")
}()
}
func f(){
fmt.Println("a")
panic(10000)
fmt.Println("b")
fmt.Println("f")
}
結(jié)果:
ubuntu@VM-0-15-ubuntu:~/taoge/go$ go run test.go
a
c
d
panic: 10000
goroutine 1 [running]:
panic(0x4b8480, 0xc82000a2c0)
/usr/lib/go-1.6/src/runtime/panic.go:481 +0x3e6
main.f()
/home/ubuntu/taoge/go/test.go:34 +0x115
main.main()
/home/ubuntu/taoge/go/test.go:25 +0x35
exit status 2
ubuntu@VM-0-15-ubuntu:~/taoge/go$
看代碼:
package main
import "fmt"
func main(){
defer func(){
fmt.Println("c")
if err := recover(); err != nil{
fmt.Println(err)
}else{
fmt.Println("hehe")
}
if err := recover(); err != nil{
fmt.Println(err)
}else{
fmt.Println("haha")
}
fmt.Println("d")
}()
f()
defer func(){
fmt.Println("e")
}()
}
func f(){
fmt.Println("a")
panic(10000)
fmt.Println("b")
fmt.Println("f")
}
結(jié)果:
ubuntu@VM-0-15-ubuntu:~/taoge/go$ go run test.go
a
c
10000
haha
d
ubuntu@VM-0-15-ubuntu:~/taoge/go$
好好體會(huì)下。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
您可能感興趣的文章:- Go中recover與panic區(qū)別詳解
- go panic時(shí)如何讓函數(shù)返回?cái)?shù)據(jù)?
- Golang捕獲panic堆棧信息的講解
- go語(yǔ)言異常panic和恢復(fù)recover用法實(shí)例
- GO語(yǔ)言異常處理機(jī)制panic和recover分析
- 詳解go中panic源碼解讀