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)
}
相关推荐
审判长烧鸡6 小时前
GO闭包【4】“普通闭包”与“循环闭包”之间捕获的核心区别
go·捕获·闭包
审判长烧鸡8 小时前
Go 闭包【1】基础
go·闭包
ん贤13 小时前
Go GC垃圾回收机制
算法·go·gc·垃圾回收
donecoding14 小时前
类型与语法的“直觉对齐”:TS 切入的 Go 语言初体验
前端·typescript·go
审判长烧鸡14 小时前
GO闭包【3】闭包捕获
go·闭包·闭包捕获
审判长烧鸡14 小时前
Go闭包【2】 1.22 对 for 循环里闭包陷阱的那个“史诗级更新”
go·闭包
stark张宇17 小时前
Go语言必知的5个核心知识点:init、路径、输出、切片、Map
后端·go
王码码20351 天前
Go语言中的配置管理:从Viper到环境变量
后端·golang·go·接口
王码码20352 天前
Go语言的包管理:从GOPATH到Go Modules
后端·golang·go·接口
Go_error3 天前
Go 并发控制 Wait & Cancel
后端·go