登录
首页 >  Golang >  Go教程

go语言的panic和recover函数用法实例

来源:脚本之家

时间:2023-02-24 15:41:00 330浏览 收藏

本篇文章向大家介绍《go语言的panic和recover函数用法实例》,主要包括函数、recover、gopanic,具有一定的参考价值,需要的朋友可以参考一下。

Golang 有2个内置的函数 panic()recover(),用以报告和捕获运行时发生的程序错误,与 error 不同,panic-recover 一般用在函数内部。一定要注意不要滥用 panic-recover,可能会导致性能问题,我一般只在未知输入和不可靠请求时使用。

golang 的错误处理流程:当一个函数在执行过程中出现了异常或遇到 panic(),正常语句就会立即终止,然后执行 defer 语句,再报告异常信息,最后退出 goroutine。如果在 defer 中使用了 recover() 函数,则会捕获错误信息,使该错误信息终止报告。

看代码:

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")
}

结果:

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")
}

结果:

ubuntu@VM-0-15-ubuntu:~/taoge/go$ go run test.go
a
c
10000
haha
d
ubuntu@VM-0-15-ubuntu:~/taoge/go$ 

好好体会下。

总结

好了,本文到此结束,带大家了解了《go语言的panic和recover函数用法实例》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>