ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

go语言里多线程使用recover捕获panic错误(防止一个子线程出错导致整个进程结束)

2021-05-24 14:01:18  阅读:188  来源: 互联网

标签:recover 线程 func time calc 多线程 panic


我们启动多线程时,可能某一个子线程的操作会出现不重要的panic错误(只需要打印日志即可,不用结束整个进程),这时我们就可以用recover来捕获panic错误,来进行处理,下面是具体实例:

 
package main

import (
    "fmt"
    "time"
    "runtime"
)

// 定义test函数
func test() {
    // 使用defer定义错误处理函数,recover捕获panic错误并处理,防止因为一个子线程出错导致主线程退出影响其他子线程工作
    defer func() {
        if err := recover(); err != nil {
            fmt.Println("panic:",err)
        }
    }()

    var m map[string]int        // 定义map,没有初始化
    m["stu"] = 100            // 没有初始化map,执行赋值操作时会报错(panic)
}

// 定义calc函数
func calc() {
    for {
        fmt.Println("i'm calc")
        time.Sleep(time.Second)
    }
}

func main() {
    num := runtime.NumCPU()      // 获取cpu数量
    runtime.GOMAXPROCS(num - 1)   // 绑定总cpu数-1的cpu上执行
    go test()      // 启动线程执行test函数
    for i :=0; i < 5; i ++ {
        go calc()      // 启动两个线程执行calc函数
    }
    time.Sleep(time.Second*2)
}

/*
执行结果为:
i'm calc
i'm calc
i'm calc
i'm calc
i'm calc
panic: assignment to entry in nil map          // 没有因为这个panic影响其他线程
i'm calc
i'm calc
i'm calc
i'm calc
i'm calc
*/
https://www.cnblogs.com/hei-ma/articles/13441555.html

标签:recover,线程,func,time,calc,多线程,panic
来源: https://www.cnblogs.com/leijiangtao/p/14804057.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有