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)
}
相关推荐
Sinclair15 小时前
认识安企CMS-系统概述
开源·go
cocoCola9166719 小时前
Golang中的接口
go
赫媒派21 小时前
Gin 12年零破坏API,架构哲学如何练成?
后端·go·gin
唐青枫1 天前
别再只会 if err != nil:Go error 从错误链到工程实战详解
go
小满zs2 天前
Go语言第二章(小无相功)
后端·go
妙码生花2 天前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
老鹰8622 天前
Google Wire 被官方抛弃,Uber Fx 启动就 panic,Go DI 还有救吗?
go
golang学习记2 天前
Go面试官:说说struct{}为什么占用0字节
go
喵个咪3 天前
Go Wind UBA 拆解系列 - 架构总览:三服务、数据流与契约优先
大数据·后端·go
喵个咪3 天前
Go Wind UBA 拆解系列 - 多租户与安全:两套隔离机制的边界
大数据·后端·go