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)
}
相关推荐
漓漾li20 分钟前
每日面试题-Go全栈AI agent
go·agent·全栈
审判长烧鸡6 小时前
【PHPer转GO】之高并发场景避坑Map补充内容
go·map
扉页的墨6 小时前
Go Channel 高级用法:那个让线上服务半夜宕机的 select 死锁,我排查了6个小时
后端·面试·go
王码码203517 小时前
Go语言的内存管理:原理与实战
后端·golang·go·接口
~|Bernard|21 小时前
一.go语言中slice底层原理(2026-5-7)
golang·go
审判长烧鸡1 天前
Go 内存优化骚操作
go·内存优化
焗猪扒饭1 天前
极简案列入门golang依赖注入工具wire
后端·go
讲不出 再见2 天前
go语言-指针
go·指针
讲不出 再见2 天前
go语言-包
golang·go·package··包冲突
王中阳Go3 天前
用Go写AI Agent:我从实战图书里总结了这些核心逻辑
后端·go·ai编程