Golang中的panic之避免和处理程序中的异常情况

作者:米花町的小侦探 时间:2024-02-20 10:22:49 

1.panic是什么

panic() 是一个内建的函数

2.panic有什么用

作用:可以使用panic停止程序继续运行,所以大多数都是在demo中使用,项目中尽量少使用,毕竟我们不能让我们的项目突然退出了。

1.首先我们来看下面的这段代码

package main
import "fmt"
func main() {
fmt.Println("main开始")
fmt.Println("main结束")
}

这是一段非常简单的代码,运行结果如下,我们可以看到整个程序正常的运行然后结束了。

yantao@hasee:~/go/src/panic_learn$ go run main.go 
main开始
main结束

2.我们试试添加panic函数

package main
import "fmt"
func main() {
  fmt.Println("main开始")
  panic("这是一个panic")//第8行
  fmt.Println("main结束")
}

结果如下,我们看到当panic函数运行之后,后面的代码就不在执行了,主程序main退出。

yantao@hasee:~/go/src/panic_learn$ go run main.go 
main开始
panic: 这是一个panic

goroutine 1 [running]:
main.main()
        /home/yantao/go/src/panic_learn/main.go:8 +0x65
exit status 2

3.如果panic出现在被调用者内呢

package main
import "fmt"
func main() {
fmt.Println("main开始")
fun1()
panic("这是一个panic")
fmt.Println("main结束")
}
func fun1()  {
fmt.Println("fun1开始")
panic("这是一个fun1的panic") //第17行
fmt.Println("fun1结束")
}

我们发现程序在17行运行之后,fun1停止向下继续运行了,而且调用者main也停止在调用fun1的地方了,并且退出了主程序main函数。

yantao@hasee:~/go/src/panic_learn$ go run main.go 
main开始
fun1开始
panic: 这是一个fun1的panic

goroutine 1 [running]:
main.fun1()
        /home/yantao/go/src/panic_learn/main.go:17 +0x65
main.main()
        /home/yantao/go/src/panic_learn/main.go:7 +0x57
exit status 2

内建函数panic停止当前Go程的正常执行。当函数fun1调用panic时,fun1的正常执行就会立刻停止。fun1返回给其调用者G。G如同fun1一样行动,层层返回,直到主函数main。然后程序被终止,然后打印该恐慌的实参值(“这是一个fun1的panic”)。

下面的代码也出现了panic

package main
import (
"fmt"
)
func main() {
fmt.Println("main开始")
div()
fmt.Println("main结束") //第17行
}
func div()  {
var a = 5
var b = 0
res := a /b
fmt.Println(res)
}

由于panic,程序停止了

yantao@hasee:~/go/src/panic_learn$ go run main.go 
main开始
panic: runtime error: integer divide by zero

goroutine 1 [running]:
main.div()
        /home/yantao/go/src/panic_learn/main.go:19 +0x11
main.main()
        /home/yantao/go/src/panic_learn/main.go:10 +0x5b
exit status 2

但是我们不想因为div的错误让main停止,让第12行也能继续运行。这就引出了 defer…recover

3.defer…recover

defer…recover用来捕获错误,defer 后面跟上匿名函数的调用,程序不会因为panic而中断。

package main
import (
"fmt"
)
func main() {
fmt.Println("main开始")
div()
fmt.Println("main结束") //第12行
}
func div()  {
defer func() {
err := recover()
if err != nil {
//err确实存在
fmt.Println("捕获到错误啦,错误是:",err)
}
}()
var a = 5
var b = 0
res := a /b
fmt.Println(res)
}

我们看到main函数能够继续执行了,没有被中断。

yantao@hasee:~/go/src/panic_learn$ go run main.go 
main开始
捕获到错误啦,错误是: runtime error: integer divide by zero
main结束

来源:https://blog.csdn.net/yantao_1994/article/details/129320142

标签:Golang,异常处理,Panic
0
投稿

猜你喜欢

  • python字符串判断密码强弱

    2021-05-09 04:20:04
  • asp sqlserver 执行存储过程返回记录集报对象关闭时不允许操作

    2011-03-11 10:57:00
  • python神经网络特征金字塔FPN原理

    2023-12-20 02:21:01
  • Python中hash加密简介及使用方法

    2022-08-16 01:06:06
  • 新建文件时Pycharm中自动设置头部模板信息的方法

    2021-08-18 11:56:46
  • 自己用python做的一款超炫酷音乐播放器

    2021-05-26 04:47:35
  • JS上传图片前实现图片预览效果的方法

    2024-04-30 10:10:12
  • 表单制作方式大比拼

    2008-10-09 11:32:00
  • python3.6 实现AES加密的示例(pyCryptodome)

    2022-07-05 08:17:08
  • MySQL的时间差函数TIMESTAMPDIFF、DATEDIFF的用法

    2024-01-25 04:39:33
  • python中的txt文件转换为XML

    2021-12-05 10:45:48
  • python冒泡排序算法的实现代码

    2021-09-08 03:48:27
  • Vue 实现轮播图功能的示例代码

    2024-05-11 09:14:15
  • 最炫Python烟花代码全解析

    2022-02-16 13:07:53
  • 《写给大家看的设计书》阅读笔记之色彩

    2009-07-30 12:45:00
  • Python聚类算法之基本K均值实例详解

    2023-07-14 12:49:08
  • flask框架中的cookie和session使用

    2023-04-08 03:33:28
  • CentOS7使用yum安装Golang的超详细步骤

    2024-04-30 10:08:01
  • 详解Vue调用手机相机和相册以及上传

    2024-04-27 16:13:47
  • python调用动态链接库的基本过程详解

    2023-05-31 13:24:00
  • asp之家 网络编程 m.aspxhome.com