ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

对golang的Channel初始化的有缓存与无缓存解释

2021-09-12 17:59:53  阅读:277  来源: 互联网

标签:received 缓存 jobs make golang job Channel sent


参考文章:对golang的Channel初始化的有缓存与无缓存解释 - Go语言中文网 - Golang中文社区

这篇文章没看懂,简单说下就是channel初始化的时候,make了缓存长度的话,就是带缓存的,没有make长度,就是不带缓存的。带缓存的只要缓存没有满,往channel里面写东西和从channel里面读东西就都是异步的,不会被阻塞的。但是如果是不带缓存的,必须是发送的东西有人收到后才能继续下一次发送;或者是接受的东西必须收到后才能继续下一次的接受。

func main() {
	jobs := make(chan int, 1)
	done := make(chan bool)
	go func() {
		//fmt.Println("GoStart")
		for i := 1; ; i++ {
			//fmt.Println("GoforSTART", i)
			j, more := <-jobs
			if more {
				fmt.Println("received job", j)
			} else {
				fmt.Println("received all jobs")
				done <- true
				return
			}
			//fmt.Println("GoforEND", i)
		}
	}()
	for j := 1; j <= 3; j++ {
		//fmt.Println("OutFOR", j)
		jobs <- j
		fmt.Println("sent job", j)
	}

	close(jobs)
	fmt.Println("sent all jobs")

	<-done
}

以参考的文章里面的程序举例,如上图,当有缓存的时候,执行结果如下(每次结果不一样),只有当缓存满的时候才会被阻塞:

sent job 1
sent job 2
received job 1
received job 2
received job 3
sent job 3
sent all jobs
received all jobs
 

或者

received job 1
sent job 1
sent job 2
sent job 3
sent all jobs
received job 2
received job 3
received all jobs

当没有缓存时,执行结果如下(每次结果不一样):

received job 1
sent job 1
sent job 2
received job 2
received job 3
sent job 3
sent all jobs
received all jobs
 

或者 

sent job 1
received job 1
received job 2
sent job 2
sent job 3
sent all jobs
received job 3
received all jobs
 

或者 

标签:received,缓存,jobs,make,golang,job,Channel,sent
来源: https://blog.csdn.net/qq_32625545/article/details/120253447

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有