Golang 并发控制的两种模式
🕓 Tue, 15 Aug 2017 by GolangNote
两种常用的并发控制,使用channel 和 WaitGroup
package main
import (
"fmt"
"sync"
"time"
)
func main() {
fmt.Println("Hello, 世界")
handle1()
handle2()
}
func handle1() {
// 通过无缓冲通道来实现多 goroutine 并发控制
// create channel to synchronize
done := make(chan bool) // 无缓冲通道
defer close(done)
go func() {
time.Sleep(9 * time.Second)
fmt.Println("one done")
done <- true
}()
go func() {
time.Sleep(5 * time.Second)
fmt.Println("two done")
done <- true
}()
// wait until both are done
for c := 0; c < 2; c++ {
<-done
}
fmt.Println("handle1 done")
// 当主 goroutine 运行到 <-done 接受 channel 的值的时候,如果该 channel 中没有数据,就会一直阻塞等待,直到有值。
}
func handle2() {
// 通过sync包中的WaitGroup 实现并发控制
var wg sync.WaitGroup
wg.Add(1)
go func(wg *sync.WaitGroup) {
time.Sleep(5 * time.Second)
fmt.Println("1 done")
wg.Done()
}(&wg)
wg.Add(1)
go func(wg *sync.WaitGroup) {
time.Sleep(9 * time.Second)
fmt.Println("2 done")
wg.Done()
}(&wg)
wg.Wait()
fmt.Println("handle2 done")
// 在 sync 包中,提供了 WaitGroup ,它会等待它收集的所有 goroutine 任务全部完成,在主 goroutine 中 Add(delta int) 索要等待goroutine 的数量。在每一个 goroutine 完成后 Done() 表示这一个goroutine 已经完成,当所有的 goroutine 都完成后,在主 goroutine 中 WaitGroup 返回。
}
本文网址: https://golangnote.com/topic/184.html (转载注明出处)
关于GolangNote:记录在工作中使用golang 遇到、面临的相关问题及解决方法。如果你在这里获得一些知识或信息,解决你的编程问题,请考虑捐赠给不幸的人或者你喜欢的慈善机构,除捐赠外,种植树木、志愿服务或减少排碳的行为也很有益处。如果你有任何问题可以在下面 留言
Be the first to comment!
Relative Articles
Recent Go Articles
- Golang 把cookie 字符串解析为cookie 结构
- Golang 计算字符串中包含某个或某些字符集的个数
- 使用Golang 对文件增删写读操作备忘
- Go Modules 使用备忘
- 使用Golang 简单删除图片exif 信息
- 谷歌翻译的 golang 库推荐
- Go 1.13.2 与1.13.3 紧急更新
- golang 人脸检测识别库
- Go build 错误 “stackcheck redeclared in this block previous declaration”的解决方法
- Golang phantomjs 动态代理实现
- Golang chrome debug protocol 库推荐
- Golang 随机打乱数组/Slice
- Golang sync.WaitGroup 的 Wait 超时处理
- Golang实现简单的Socks5代理
- Golang 用snappy + Base64 简单压缩加密进行网络传输
- Golang http IPv4/IPv6 服务
- golang 全角半角相互转换
- 在自己的网站部署TLS 1.3
- Golang 实现/打印菜单树
- Golang telegram 机器人小试
Top Go Articles
- 用golang 标准库regexp 验证用户名和密码的合法性
- Golang http IPv4/IPv6 服务
- mismatched types time.Duration and int
- golang 用gzip 压缩、解压缩字符串
- golang 简单全局计数器实现
- Golang sync.WaitGroup 的 Wait 超时处理
- Golang telegram 机器人小试
- Golang 并发控制的两种模式
- go 获取硬盘的可用空间的方法
- iris websocket 自定义信息结构
- golang map 按value 大小排序,降序和升序
- Golang Leveldb 基本使用的例子
- go post 上传文件的例子
- golang 生成良好的唯一ID/uuid库比较
- golang 获取用户真实访问ip 地址
- Golang webview 做桌面应用及跨平台编译
- Golang http.Post 用最小的内存发送大文件
- golang image 智能合并图片
- Golang string 和byte 操作性能比较
- golang 使用crypto/rand 生成随机数