golang协程的最佳实践与context包的基本使用
1.协程最佳实践,多个协程并发求素数
点击查看代码
var wg sync.WaitGroup
func Prime(num int) bool {
if num == 1 {
return false
}
for i := 2; i*i <= num; i++ {
if num%i == 0 {
return false
}
}
return true
}
func test1(ch chan int) {
for i := 1; i <= 100; i++ {
ch <- i
}
close(ch)
defer wg.Done()
}
func test2(ch chan int, ch2 chan int, exitChan chan bool) {
for v := range ch {
if Prime(v) {
ch2 <- v
}
}
exitChan <- true
defer wg.Done()
}
func test3(ch2 chan int, exitChan chan bool) {
for v := range ch2 {
fmt.Println(v)
}
exitChan <- true
defer wg.Done()
}
func main() {
var ch = make(chan int, 20)
var ch2 = make(chan int, 20)
var exitChan = make(chan bool, 5)
//for i := 0; i < 5; i++ {
wg.Add(1)
go test1(ch)
//}
for i := 0; i < 5; i++ {
wg.Add(1)
go test2(ch, ch2, exitChan)
}
//for i := 0; i < 5; i++ {
wg.Add(1)
go test3(ch2, exitChan)
//}
wg.Add(1)
go func() {
for i := 0; i < 5; i++ {
<-exitChan
}
close(ch2)
}()
wg.Done()
wg.Wait()
}
ch管道用于存放1~100的数字,放完后关闭,ch2管道用于统计素数,test3()函数用于从ch2管道取出数据并打印
2.Context包的基本使用
使用context包目的是管理协程的生命周期,以及管理多级协程,以下为Context()基本函数的使用
点击查看代码
func test(msg chan int, ctx context.Context) {
t := time.Tick(time.Second)
for range t {
select {
case n := <-msg:
fmt.Println("job", n, "done")
case <-ctx.Done():
fmt.Println("return...", ctx.Value(k))
return
}
}
}
type str string
var k str = "name"
var v str = "YueSe"
func main() {
// ctx, clear := context.WithCancel(context.Background())
ctx := context.WithValue(context.Background(), k, v)
ctx, clear := context.WithDeadline(ctx, time.Now().Add(time.Second*5))
var message = make(chan int)
// var flag = make(chan bool)
go test(message, ctx)
for i := 0; i < 10; i++ {
message <- i
}
clear()
// flag <- true
time.Sleep(time.Second)
fmt.Println("all done")
}
Done
golang协程的最佳实践与context包的基本使用的更多相关文章
- 面试必问:Golang高阶-Golang协程实现原理
引言 实现并发编程有进程,线程,IO多路复用的方式.(并发和并行我们这里不区分,如果CPU是多核的,可能在多个核同时进行,我们叫并行,如果是单核,需要排队切换,我们叫并发) 进程和线程的区别 进程是计 ...
- Golang协程实现流量统计系统(3)
进程.线程.协程 - 进程:太重 - 线程:上下文切换开销太大 - 协程:轻量级的线程,简洁的并发模式 Golang协程:goroutine Hello world package main impo ...
- golang协程同步的几种方法
目录 golang协程同步的几种方法 协程概念简要理解 为什么要做同步 协程的几种同步方法 Mutex channel WaitGroup golang协程同步的几种方法 本文简要介绍下go中协程的几 ...
- Python与Golang协程异同
背景知识 这里先给出一些常用的知识点简要说明,以便理解后面的文章内容. 进程的定义: 进程,是计算机中已运行程序的实体.程序本身只是指令.数据及其组织形式的描述,进程才是程序的真正运行实例. 线程的定 ...
- Golang协程实现流量统计系统(1)
# 学习内容: # 学习目标: 学习Golang的基础开发 常用的Golang编程技艺 精巧省力的Go Lib 协程的真实应用实践 与其他语言对比着学 协程并发模型的深度应用 Growth hacki ...
- golang协程池设计
Why Pool go自从出生就身带“高并发”的标签,其并发编程就是由groutine实现的,因其消耗资源低,性能高效,开发成本低的特性而被广泛应用到各种场景,例如服务端开发中使用的HTTP服务,在g ...
- Golang 协程调度
一.线程模型 N:1模型,N个用户空间线程在1个内核空间线程上运行.优势是上下文切换非常快但是无法利用多核系统的优点. 1:1模型,1个内核空间线程运行一个用户空间线程.这种充分利用了多核系统的优势但 ...
- golang 协程嵌套,会产生依赖关系(父子关系)么?
编码时冒出一个问题:在一个协程内部,再创建一个或多个协程,是否会产生依赖关系? 做了一个小实验,这里随笔记录一下经过,备注后续深入研究. test代码: package main import ( & ...
- Golang协程与通道整理
协程goroutine 不由OS调度,而是用户层自行释放CPU,从而在执行体之间切换.Go在底层进行协助实现 涉及系统调用的地方由Go标准库协助释放CPU 总之,不通 ...
- 关于协程:nodejs和golang协程的不同
nodejs和golang都是支持协程的,从表现上来看,nodejs对于协程的支持在于async/await,golang对协程的支持在于goroutine.关于协程的话题,简单来说,可以看作是非抢占 ...
随机推荐
- Linux 应用案例开发手册——基于Zynq-7010/20工业开发板
目 录 1 开发案例说明 4 2 Linux 常用开发案例 4 2.1 tl_led_flash 案例 4 2.2 tl_key_test 案例 7 2.3 tl_can_echo 案例 11 2.4 ...
- Mac制作U盘启动项
导读 鄙人刚买回来的电脑,自带系统版本:10.14.5(19款的),有一天,提示系统升级,升到了10.15.4,从此落下了后遗症,mac系统密码输入完之后,读条读到2/3的时候,会黑屏闪一下,百思不得 ...
- 记一次 .NET某上位视觉程序 离奇崩溃分析
一:背景 1. 讲故事 前段时间有位朋友找到我,说他们有一个崩溃的dump让我帮忙看下怎么回事,确实有太多的人在网上找各种故障分析最后联系到了我,还好我一直都是免费分析,不收取任何费用,造福社区. 话 ...
- python配置国内pypi镜像源操作步骤
使用pip config命令设置默认镜像源,使用国内的源,提高安装速度 操作步骤 临时方式pip install xxx -i https://pypi.tuna.tsinghua.edu.cn/si ...
- [oeasy]python0135_python_语义分析_ast_抽象语法树_abstract_syntax_tree
语义分析_抽象语法树_反汇编 回忆 上次回顾了一下历史 python 是如何从无到有的 看到 Guido 长期的坚持和努力 添加图片注释,不超过 140 字(可选) python究竟是 ...
- Kafka kafka在windows下的安装与配置
kafka在windows下的安装与配置 By: 授客 QQ:1033553122 1.测试环境.............................................. ...
- 兼容sentry协议的轻量级监控,glitchtip
前言 上一篇文章说了重启 sentry 的事 因为过程太折腾了,一度想过放弃 sentry 换成其他比较轻量级的开源监控系统 这不就给我找到了另外俩个 https://glitchtip.com/ h ...
- mysql 忘记root密码怎么办?
忘记root可以跳过grant table来登录 1.打开命令行输入以下命令 mysqld -nt --grant-skip-tables 2.在打开一个新命令行,输入以下命令可以登录, mysql ...
- MFC的消息反射
这边我用对话框来测试mfc的消息反射 当对话框初始化完成之后,点击按钮,首先相应CDialog::OnCommand其中wpARAM(低八位nId,高八位子控件句柄) 和LPARAM(句柄) OnCo ...
- 百度翻译network里没有sug(文章发布时间2022年10月)
百度翻译已经更新,现在的百度翻译分为两个阶段翻译,第一个阶段识别你的翻译字符是什么类型语言 第二阶段生成随机sign加携带token以post表单方式上传数据,返回json数据 尚硅谷在B站发布的的爬 ...