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)
}
相关推荐
小熊吃保安17 小时前
Excel下载变成了ZIP?Docker 容器里的 Content-Type 离奇失踪案
docker·go
Coding君17 小时前
每日一Go-58、NATS 如何做到高可用?NATS集群部署方式来了
go
审判长烧鸡1 天前
Go命名规则【1】文件命名的“潜规则”
go·命名·新手·下划线全名
stark张宇2 天前
深入Go运行时:数值溢出、浮点精度与栈堆分配决策
后端·go
审判长烧鸡3 天前
Go命名规则【2】全场景命名避坑指南
go·命名规则·ai问答
众少成多积小致巨3 天前
Soong构建入门
android·go·编译器
ServBay3 天前
2026年 Go 开发中没有它就不行的 10 个库
后端·go
PFinal社区_南丞4 天前
Go 官方终于出手了!gopls 内置 MCP,AI 编程效率狂飙 88%
后端·go
ん贤4 天前
如何设计一个灵活、高效、安全的 AI 工具系统
人工智能·安全·go