Golang控制子gorutine退出,并阻塞等待所有子gorutine全部退出
Golang控制子gorutine退出,并阻塞等待所有子gorutine全部退出
需求
程序有时需要自动重启或者重新初始化一些功能,就需要退出之前的所有子gorutine,并且要等待所有子gorutine全部退出,以下demo可以提供思路
实现demo
package main
import (
"fmt"
"sync"
"time"
)
func main() {
channal1 := make(chan bool,3)
wg := new(sync.WaitGroup)
wg.Add(3)
go g1(channal1,wg)
go g2(channal1,wg)
go g3(channal1,wg)
time.Sleep(time.Second * 10)
channal1 <- true
channal1 <- true
channal1 <- true
wg.Wait()
fmt.Println("++++>>>>all gorutine finish...<<<<++++")
close(channal1)
}
func g1(c chan bool,wg *sync.WaitGroup) {
i := 0
for{
select {
case <- c:
fmt.Printf("@@@---->>>>>g1 end<<<<<----+++\n")
wg.Done()
return
default:
i++
fmt.Printf("+++>>>>>g1 working---%d---<<<<<+++\n",i)
}
time.Sleep(time.Second * 2)
}
}
func g2(c chan bool,wg *sync.WaitGroup) {
i := 0
for{
select {
case <- c:
fmt.Printf("@@@---->>>>>g2 end<<<<<----+++\n")
wg.Done()
return
default:
i++
fmt.Printf("+++>>>>>g2 working---%d---<<<<<+++\n",i)
}
time.Sleep(time.Second * 2)
}
}
func g3(c chan bool,wg *sync.WaitGroup) {
i := 0
for{
select {
case <- c:
fmt.Printf("@@@---->>>>>g3 end<<<<<----+++\n")
wg.Done()
return
default:
i++
fmt.Printf("+++>>>>>g3 working---%d---<<<<<+++\n",i)
}
time.Sleep(time.Second * 2)
}
}
运行结果
+++>>>>>g2 working---1---<<<<<+++
+++>>>>>g1 working---1---<<<<<+++
+++>>>>>g3 working---1---<<<<<+++
+++>>>>>g2 working---2---<<<<<+++
+++>>>>>g1 working---2---<<<<<+++
+++>>>>>g3 working---2---<<<<<+++
+++>>>>>g2 working---3---<<<<<+++
+++>>>>>g1 working---3---<<<<<+++
+++>>>>>g3 working---3---<<<<<+++
+++>>>>>g2 working---4---<<<<<+++
+++>>>>>g1 working---4---<<<<<+++
+++>>>>>g3 working---4---<<<<<+++
+++>>>>>g2 working---5---<<<<<+++
+++>>>>>g3 working---5---<<<<<+++
+++>>>>>g1 working---5---<<<<<+++
@@@---->>>>>g2 end<<<<<----+++
@@@---->>>>>g1 end<<<<<----+++
@@@---->>>>>g3 end<<<<<----+++
++++>>>>all gorutine finish...<<<<++++
Golang控制子gorutine退出,并阻塞等待所有子gorutine全部退出的更多相关文章
- golang中如何阻塞等待所有goroutines都完成
有一天,一个人问了我此问题,回头仔细翻阅了一下资料,仔细的想了一下,这个问题的解决有两种方案.方案一:也是推荐方案,也是官方推荐方案,涉及到一个写并发经常关注的模块sync模块,利用里面的sync.W ...
- Python进阶----进程间数据隔离, join阻塞等待, 进程属性, 僵尸进程和孤儿进程, 守护进程
Python进阶----进程间数据隔离, join阻塞等待, 进程属性, 僵尸进程和孤儿进程, 守护进程 一丶获取进程以及父进程的pid 含义: 进程在内存中开启多个,操作系统如何区分这些进程, ...
- 八、阻塞等待异步结果FutureTask
一.简介 默认的异步任务有些难以控制,有时候我们希望在当前线程获取异步任务的结果.FutureTask可以帮助我们实现 JDK文档:http://tool.oschina.net/uploads/ap ...
- JUC 并发编程--06, 阻塞队列(7种), 阻塞等待 api的 代码验证
这些队列的 api ,就是添加队列,出队列,检测对首元素, 由于 add()--remove(), offer()--poll(),太简单这里不做验证, 只验证后二组api: 阻塞等待( put()- ...
- 移动端框架篇-控制子容器的滑屏框架-fullPage.js
控制子容器法 方法是只显示其中一个子元素,其它隐藏,滑屏时隐藏当前元素,并显示当前元素的下一个同辈元素~ 这里采用fullPage框架,库大小7.69K~ fullPage框架的页面样式无需自定义,已 ...
- Dynamic CRM 2013学习笔记(十八)根据主表状态用JS控制子表自定义按钮
有时要根据主表的审批状态来控制子表上的按钮要不要显示,比如我们有一个需求审批通过后就不能再上传文件了. 首先打开Visual Ribbon Editor, 如下图,我们可以利用Enable Rules ...
- CSS3 04. 伸缩布局、设置主轴,侧轴方向、主/侧轴对齐方式、 伸缩比例、元素换行、换行控制、覆盖父元素的align-items;控制子元素顺序、web字体、突变字体
CSS3 在布局方面做了非常大的改进,对块级元素的布局排列变得十分灵活,适应性非常强,其强大的伸缩性,在响应式开发中可以发挥极大的作用.(兼容性不好) 必要元素: 指定一个盒子为伸缩盒子 displa ...
- c#等待所有子线程执行完毕方法
当我们在使用线程中,你会发现主线结束后子线程的结果才显示出来.现在我要等待所以子线程结束,然后在显示结果,怎么做呢? 方法如下: 1.使用 ManualResetEvent,代码如下: using ...
- Java多线程--让主线程等待所有子线程执行完毕
数据量很大百万条记录,因此考虑到要用多线程并发执行,在写的过程中又遇到问题,我想统计所有子进程执行完毕总共的耗时,在第一个子进程创建前记录当前时间用System.currentTimeMillis() ...
随机推荐
- Windows 程序自动更新方案: Squirrel.Windows
Windows 程序自动更新方案: Squirrel.Windows 1. Squirrel Squirrel 是一组工具和适用于.Net的库,用于管理 Desktop Windows 应用程序的安装 ...
- 1Spring注入小结
Spring注入小结 (在Application.xml中) Spring学习笔记 周芋杉2021/5/14 1.基本注入类型注入 注入前的准备 <bean id="#配置文件的唯一标 ...
- 将top命令的输出,写入到文件中 top -b -n 1 -d 3 >>file.txt
top -b -n 1 -d 3 >>file.txt 解析: -b :batch模式,可以重定向到文件中 -n 1:一共取1次top数据.后边加数字,表示次数 -d 3:每次top时间间 ...
- Linux_网络基础管理
一.网卡的命名 1.传统网卡命名 eth0.eth1.eth2.eth3......... wlan0.wlan1.waln2.wlan3......... 2.RHEL7命名机制 systemd对网 ...
- QT学习笔记(一)——Helloworld
QT学习笔记(一)--Helloworld 一.调试的基本方法: Log调试法 --在代码中加入一定的打印语句 --打印程序状态和关键变量的值 断点调试法: --在开发环境中的对应代码行加上断点 -- ...
- 10.27-Redis-mz 深入浅出Redis
深入浅出Redis 1.Redis的发展史 Redis[Remote Directory Server]:远程服务器字典 2.下载安装Redis 1>Linux下安装Reids ...
- REST 架构风格详解
什么是 REST 架构风格 REST(Representational State Transfer)是表述性状态转移.分布式超媒体软件的一种架构风格,它基于使用 HTTP.URI 等现有的广泛流行的 ...
- git push 时发生错误 error: src refspec master does not match any. error: failed to push some refs to
很多相关解决办法都是最后要 push 到远端的 master 上,但很多其实要求不能把个人的修改内容直接 push 到 master 主分支. 因此,当我想将本地 feature/work1 分支的修 ...
- Wrong——Python
1.向MySQL中插入时间(年月日时分秒),在时分秒处报错.在年月日与时分秒中间有个空格.解决办法:在sql语句中时间用一个" "包起来就可以了.. 2.在Ubuntu的cront ...
- 通过CSS设计模式搭建自己系统的CSS架构
theme: qklhk-chocolate 传统的CSS书写风格是随意命名,堆叠样式,造成了混乱不堪的结果,复杂页面的样式书写通常会出现几百行甚至上千行的代码,CSS设计模式在实际应用中的横空出世拯 ...