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)
}
相关推荐
Java水解6 分钟前
为何最终我放弃了 Go 的 sync.Pool
后端·go
得物技术3 小时前
Golang HTTP请求超时与重试:构建高可靠网络请求|得物技术
java·后端·go
喵个咪1 天前
Kratos 下使用 Protobuf FieldMask 完全指南
后端·go
Mgx1 天前
内存网盘 - Go语言实现的WebDAV内存文件系统
go
百锦再2 天前
第15章 并发编程
android·java·开发语言·python·rust·django·go
虫洞没有虫2 天前
Go语言学习笔记(一)
笔记·go·区块链
wohuidaquan3 天前
AI为何跳过你?GEO中的E-E-A-T权重
go
百锦再3 天前
选择Rust的理由:从内存管理到抛弃抽象
android·java·开发语言·后端·python·rust·go
百锦再3 天前
大话Rust的前生今世
开发语言·后端·rust·go·内存·时间·抽象
俞凡5 天前
Golang 构建网络漏洞扫描器
go