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)
}
相关推荐
审判长烧鸡5 小时前
GO时区【2】跨时区应用
go·存储·时区
审判长烧鸡6 小时前
Go结构体与指针【2】接收者应该怎么用
go·指针·结构体·接收者
王中阳Go9 小时前
2026年了,还在纠结后端转AI要不要死磕Python?试试Go吧
后端·go·ai编程
审判长烧鸡14 小时前
GO结构体与指针【1】什么时候用指针
go·指针·结构体
审判长烧鸡16 小时前
GO错误处理【2】os.Exit(1)/panic/返回err的应用场景
go·异常处理·panic
审判长烧鸡16 小时前
GO时区【4】PostgreSQL时区
postgresql·go
审判长烧鸡18 小时前
GO时区【3】字段与连接设置
postgresql·go
审判长烧鸡18 小时前
GO错误处理【1】不用try-catch用什么?
go·异常处理·try-catch·panic·fatal·os.exit
Go_error2 天前
Go database/sql 基于临时 channel 传递连接
后端·go
Go_error2 天前
Go 循环栅栏
后端·go