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)
}
相关推荐
mCell8 小时前
Webhook:连接、自动化与系统集成的新范式
ci/cd·go·github
喵个咪11 小时前
开箱即用的GO后台管理系统 Kratos Admin - 支持ElasticSearch
后端·微服务·go
喵个咪11 小时前
开箱即用的GO后台管理系统 Kratos Admin - 支持InfluxDB
后端·微服务·go
喵个咪11 小时前
开箱即用的GO后台管理系统 Kratos Admin - 支持MongoDB
后端·微服务·go
喵个咪11 小时前
开箱即用的GO后台管理系统 Kratos Admin - 支持ClickHouse
后端·微服务·go
程序员爱钓鱼21 小时前
Go语言统计字符串中每个字符出现的次数 — 简易频率分析器
后端·google·go
nextera-void2 天前
深入浅出 Golang:一次精神之旅
开发语言·golang·go
DemonAvenger2 天前
Go语言实现DNS解析与域名服务的实践与优化
网络协议·架构·go
痴人说梦梦中人2 天前
Gin框架统一响应与中间件机制学习笔记
网络安全·中间件·go·gin