defer+recover机制处理错误

问题:多个协程工作,其中一个协程出现panic,导致程序崩溃

解决办法:利用defer+recover捕获panic进行处理,即使协程出现错误,主线程仍然不受影响可以继续执行

Go 复制代码
package main

import (
	"fmt"
	"time"
)

func main() {

	go printNum()
	go devide()

	time.Sleep(time.Second * 5)
}

// 输出数字
func printNum() {
	for i := 1; i <= 10; i++ {
		fmt.Println(i)
	}
}

// 除法操作
func devide() {
	defer func() {
		err := recover()
		if err != nil {
			fmt.Println("devide()出现错误:", err)
		}
	}()
	num1 := 10
	num2 := 0
	result := num1 / num2
	fmt.Println(result)
}
相关推荐
用户67570498850216 小时前
Go 语言里判断字符串为空,90% 的人都写错了!
后端·go
用户67570498850216 小时前
Go 进阶必修:90% 的人都没用对的“表驱动法”
后端·go
知恒2 天前
Go语言接口与多态
go
知恒2 天前
Go语言变量与数据类型
go
知恒2 天前
Go包管理与模块化
go
HokKeung2 天前
飞书 lark-cli 如何存储 tenant_access_token 和 user_access_token
人工智能·go
止语Lab2 天前
sync.Pool 的真正分界线不是对象大小——一次 benchmark 翻车记录
go
HokKeung2 天前
Go 里的 IO 应该怎么管理
go
喵个咪2 天前
Go-Wind HTTP 服务器从入门到精通
后端·http·go
喵个咪2 天前
Go-Wind gRPC 服务器从入门到精通
后端·go·grpc