本篇文章给大家介绍有关Golang的相关知识,聊聊一个非常好用的golang并发控制库,希望对大家有所帮助。

Concurrency

Build Status

install

GOPROXY=https://goproxy.cn go get -v github.com/lxzan/concurrency@latest

Feature

  • 并发协程数量限制
  • 支持 contex.Contex
  • 支持 panic recover, 返回包含错误堆栈的 error
  • 递归实现的任务调度, 不依赖 time.Tickerchannel

Usage

  • WorkerGroup 工作组, 添加一组任务, 等待执行完成, 可以很好的替代WaitGroup.
package mainimport (
    "fmt"
    "github.com/lxzan/concurrency"
    "sync/atomic")func main() {
    sum := int64(0)
    w := concurrency.NewWorkerGroup()
    for i := int64(1); i <= 10; i++ {
        w.AddJob(concurrency.Job{
            Args: i,
            Do: func(args interface{}) error {
                fmt.Printf("%v ", args)
                atomic.AddInt64(&sum, args.(int64))
                return nil
            },
        })
    }
    w.StartAndWait()
    fmt.Printf("sum=%d\n", sum)}
4 5 6 7 8 9 10 1 3 2 sum=55
  • WorkerQueue 工作队列, 可以不断往里面添加任务, 一旦有CPU资源空闲就去执行【

    分享一个非常好用的GO并发控制库 !