目录
1.panic是什么2.panic有什么用3.defer…recover1.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: 这是一个panicgoroutine 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的panicgoroutine 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 zerogoroutine 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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
关键词:
凡注有"星岛中文网"或电头为"星岛中文网"的稿件,均为星岛中文网独家版权所有,未经许可不得转载或镜像;授权转载必须注明来源为"星岛中文网",并保留"星岛中文网"的电头。
精选 导读
女子穿高跟鞋单脚站立上演“练瑜伽式”骑车 交通
道路千万条,安全第一条。11月4日,有网友在广州的路上拍到惊人一幕。只见一位女子在花都地铁广场站迎宾大道马路上大秀车技,穿高跟鞋单脚
山东女子忘拉手刹致溜车 竟徒手将车推了回去
近日,山东女子忘拉手刹致溜车,徒手推回SUV的视频在网上热传,网友调侃:谁还敢惹女司机。据报道,11月4日,山东临沂一女子停车去开铁门,
济宁一小伙边骑电动车边双手玩手机 车头疯狂摆动
11月5日,山东济宁一年轻小伙一边骑电动车,一边低头双手玩手机,所幸路过司机好心提醒。视频中,这名小伙驾驶一辆两轮电动车,双手完全脱
浙江台州出现不明飞行物 空中出现多个亮点 专家
据报道,7月26日,有多名浙江台州网友发视频称,在空中看到不明飞行物,当时空中出现了多个亮点,排在一条直线上。网传视频中,这几个明亮
离谱!潮州一女孩从古茗奶茶喝出一只壁虎 还从嘴
喝奶茶喝出一只壁虎,而且还是从嘴里给拽了出来,这画面实在是太让人无法直视。据信号财经报道,7月26日,广东潮州,女孩称在古茗奶茶内喝