Golang使用panic控制程序错误流程-世界快报

2023-05-27 12:07:10 来源:脚本之家
目录
1.panic是什么2.panic有什么用3.defer…recover

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结束

到此这篇关于Golang使用panic控制程序错误流程的文章就介绍到这了,更多相关Golang panic内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

标签:

环球热门:铂科新材(300811):股东减持股份数量过半的进展

2022年12月28日公告发布

2022-12-28 15:50:59

世界即时看!博彩公司遭黑客攻击,67000账户被窃,损失超30万!公司称登录信息由第三方泄露

大数据文摘出品作者:Caleb12月19日,卡塔尔世界杯落幕,总决赛可以说是让观众一直紧绷神经。梅西带领的...

2022-12-28 12:23:42

全球快播:保龄宝:公司麦芽糊精产品目前产销正常

每经AI快讯,有投资者在投资者互动平台提问:董秘你好,请问公司的麦芽糊精销量是否有明显提升?谢谢。...

2022-12-28 08:57:26

天天动态:当持有的基金亏损时 应该加仓还是割肉?

当持有的基金亏损时应该加仓还是割肉?

2022-12-27 21:35:47

全球速看:报废面包车在异地上路,武昌交警走访7个村镇“回收”

为方便货运,男子低价购买隐患面包车上路行驶,被交警抓获。12月26日,武汉市公安局武昌区交通大队经过...

2022-12-27 16:48:38

全球热消息:A股异动 | 裕兴股份涨5% 拟定增募资不超7亿元用于产能扩建、补充流资

格隆汇12月27日丨裕兴股份涨5 61%,报13 92元,总市值40亿元。裕兴股份26日披露2022年度向特定对象发...

2022-12-27 13:21:48

快消息!马斯克入选年度最糟科技老板:扎克伯格、贝索斯一同入列

2022年即将结束,在这一年里,世界上发生了很多事,而在科技公司行伍中,更是如同经历了一场噩梦。”,...

2022-12-27 07:52:48

前沿资讯!大悦城: 关于全资子公司收购其控股子公司少数股东权益的公告

大悦城控股集团股份有限公司第十届董事会公告证券代码:000031      证券简称:大悦城     ...

2022-12-26 18:53:48

世界球精选!日本各地暴雪已致17人死亡、百余人受伤

北海道纹别市发生大规模停电(朝日电视台)海外网12月26日电 据日本富士电视台26日报道,12月中旬起,...

2022-12-26 14:29:00

全球热点评!沪陕高速合肥至大顾店段 “四改八”扩建正式通车

沪陕高速合肥至大顾店段“四改八”扩建正式通车

2022-12-26 08:48:10
x 广告
x 广告

Copyright ©  2015-2022 现在经营网版权所有  备案号:粤ICP备18023326号-5   联系邮箱:855 729 8@qq.com