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)
}
相关推荐
用户398346161201 天前
Go-Spring 实战第 18 课 —— App 使用:启动、配置与运行期扩展
spring·go
喵个咪2 天前
技术复盘:基于 GoWind Admin 实现 Kratos 框架单体轻量化落地
后端·架构·go
9624562 天前
Go 并发实战:SingleFlight 踩坑与缓存代理优化复盘
go
唐青枫2 天前
别再把 new 当构造函数:Go new 从零值指针到实战用法
go
用户398346161202 天前
Go-Spring 实战第 17 课 —— App 运行模型:启动、运行与关闭
spring·go
9624562 天前
Go 语言 x402 支付中间件与 DeepSeek 代理开发复盘
go
明月_清风2 天前
图解 Socket 编程:一文吃透 TCP/UDP 编程模型(Go 实战版)
后端·tcp/ip·go
踏着七彩祥云的小丑2 天前
Go学习第1天:入门
开发语言·学习·golang·go
用户743835613513 天前
无锁 Hub:我的 IM 系统为什么用 channel 而不是 mutex 管理在线用户
go