当前位置: 首页 > news >正文

go sync.WaitGroup

1、数据结构

type WaitGroup struct {noCopy noCopystate atomic.Uint64 // high 32 bits are counter, low 32 bits are waiter count.sema  uint32
}

        计数器:原子变量,高32位用于为协程计数,低32位为等待计数(被Wait阻塞等待)。

        信号量:用于阻塞协程。

2、Add(x)

// 简化版// Add adds delta, which may be negative, to the [WaitGroup] counter.
// If the counter becomes zero, all goroutines blocked on [WaitGroup.Wait] are released.
// If the counter goes negative, Add panics.func (wg *WaitGroup) Add(delta int) {state := wg.state.Add(uint64(delta) << 32)v := int32(state >> 32)w := uint32(state)if v > 0 || w == 0 {return}// Reset waiters count to 0.wg.state.Store(0)for ; w != 0; w-- {runtime_Semrelease(&wg.sema, false, 0)}
}

        通过原子操作对协程计数器加减,若协程计数变为0,则将等待计数设置为0,并释放所有被信号量阻塞的协程。

3、Done()

// 简化版// Done decrements the [WaitGroup] counter by one.func (wg *WaitGroup) Done() {wg.Add(-1)
}

        计数器-1

4、Wait()

// 简化版// Wait blocks until the [WaitGroup] counter is zero.func (wg *WaitGroup) Wait() {for {state := wg.state.Load()v := int32(state >> 32)w := uint32(state)if v == 0 {// Counter is 0, no need to wait.return}// Increment waiters count.if wg.state.CompareAndSwap(state, state+1) {runtime_Semacquire(&wg.sema)return}}
}

        若协程计数为0,则直接跳过。

        若协程计数非0,则通过CAS将等待计数+1,并通过信号量阻塞协程。

http://www.lryc.cn/news/493181.html

相关文章:

  • Libevent库-http通信不同请求方式的处理
  • 关于node全栈项目打包发布linux项目问题总集
  • 常见的上、下采样方法
  • 如何解决 java.rmi.NotBoundException: RMI 中没有绑定的对象问题?亲测有效的解决方法!
  • 设计模式:14、抽象工厂模式(配套)
  • Linux环境基础开发工具使用
  • AI生成的一个.netcore 经典后端架构
  • 深度学习-48-AI应用实战之基于face_recognition的人脸识别
  • 【Rabbitmq篇】高级特性----事务,消息分发
  • Python进程和线程适用场景
  • flutter开发环境—Windows
  • 展示和添加篮球队信息--laravel与elementplus
  • 写一份客服网络安全意识培训PPT
  • 具体的技术和工具在县级融媒体建设3.0中有哪些应用?
  • 【uniapp】轮播图
  • Rust编程语言代码详细运行、编译方法
  • node.js基础学习-http模块-JSONP跨域传值(四)
  • Unity高效编程经验50条分享
  • TypeScript 泛型
  • 【Java从入门到放弃 之 条件判断与循环】
  • Ubuntu20.04安装kalibr
  • Flink 任务启动脚本-V2(包括ck启动)
  • 扫雷-完整源码(C语言实现)
  • python -从文件夹批量提取pdf文章的第n页,并存储起来
  • R Excel 文件操作指南
  • RabbitMQ 安装延迟队列插件 rabbitmq_delayed_message_exchange
  • fatal error in include chain (rtthread.h):rtconfig.h file not found
  • Java 反射(Reflection)
  • Python爬取机车网车型数据并存入Mysql数据库
  • fpga 时序分析基础