0

0

在 Go 中构建健壮的任务执行上下文

霞舞

霞舞

发布时间:2025-01-02 18:14:54

|

1034人浏览过

|

来源于php中文网

原创

在 go 中构建健壮的任务执行上下文

本文介绍一种在 Go 语言中进行更优雅的错误处理方法,尤其适用于并发任务场景。核心思想是在现有上下文基础上构建一个包装器,以便集中管理和处理任务执行过程中的错误。

挑战与解决方案

并发任务处理常常面临以下挑战:

  1. 多个 goroutine 的错误收集
  2. 线程安全性的维护
  3. 并发执行的限制
  4. 同时保留首个错误和所有错误
  5. 简洁高效的错误处理机制

为此,我们构建了一个 taskcontext 来应对这些挑战:

package taskctx

import (
    "context"
    "errors"
    "fmt"
    "sync"
)

type runfn[T any] func() (T, error)

type taskcontext struct {
    context.Context
    mu       sync.RWMutex
    err      error
    multierr []error
}

func newtaskcontext(parent context.Context) *taskcontext {
    if parent == nil {
        panic("cannot create context from nil parent")
    }
    return &taskcontext{Context: parent}
}

关键特性

  1. 线程安全错误处理:
func (c *taskcontext) witherror(err error) *taskcontext {
    if err == nil {
        return c
    }

    c.mu.Lock()
    defer c.mu.Unlock()

    c.multierr = append(c.multierr, err)
    if c.err == nil {
        c.err = err
    } else {
        c.err = errors.Join(c.err, err)
    }
    return c
}
  1. 单任务执行:
func run[T any](ctx *taskcontext, fn runfn[T]) T {
    var zero T
    if err := ctx.Err(); err != nil {
        return zero
    }

    result, err := fn()
    if err != nil {
        ctx.witherror(err)
        return zero
    }
    return result
}
  1. 并行任务执行:
func runparallel[T any](ctx *taskcontext, fns ...func() (T, error)) ([]T, error) {
    if err := ctx.Err(); err != nil {
        return nil, err
    }

    results := make([]T, len(fns))
    var resultsmu sync.Mutex
    var wg sync.WaitGroup
    wg.Add(len(fns))

    for i, fn := range fns {
        i, fn := i, fn
        go func() {
            defer wg.Done()
            result, err := fn()
            if err != nil {
                ctx.witherror(fmt.Errorf("task %d: %w", i+1, err))
            } else {
                resultsmu.Lock()
                results[i] = result
                resultsmu.Unlock()
            }
        }()
    }

    wg.Wait()
    return results, ctx.errors()
}
  1. 受限并发:
func runparallelwithlimit[T any](ctx *taskcontext, limit int, fns ...func() (T, error)) ([]T, error) {
    // ... 使用信号量实现受限并发 ...
}

使用示例

  1. 单任务执行示例:
// ... (示例代码略,与原文类似) ...
  1. 并行任务执行示例:
// ... (示例代码略,与原文类似) ...

优势

php中级教程之ajax技术
php中级教程之ajax技术

AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。它不是新的编程语言,而是一种使用现有标准的新方法,最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容,不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。《php中级教程之ajax技术》带你快速

下载
  • 线程安全:使用互斥锁保护共享资源。
  • 错误收集:同时记录首个错误和所有错误。
  • 上下文集成:与 Go 的 context 包无缝集成。
  • 通用性:支持任意返回类型。
  • 并发控制:内置支持并发限制。

测试

// ... (测试代码略,与原文类似) ...

总结

taskcontext 提供了一种在 Go 中高效处理并发任务执行和错误管理的方案,尤其适用于需要同时执行多个任务、收集所有错误、限制并发度以及保证线程安全的场景。 完整代码可在 Github 上获取。(此处需补充Github链接,如果原文提供的话)

讨论

您在 Go 中是如何处理并发任务执行和错误处理的?欢迎在评论区分享您的经验和想法!

(联系方式与原文保持一致)

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

481

2023.08.10

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

36

2026.01.18

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

99

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

148

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

56

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

40

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

19

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

107

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

44

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.8万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号