go的数据类型-其他数据类型-channel(二) 当前讯息

腾讯云 2023-04-24 18:46:36


(资料图片仅供参考)

Channel的使用示例

以下是一个使用Channel的示例程序,该程序创建了两个Goroutine,并使用Channel在它们之间进行通信和同步。

package mainimport ("fmt""time")func worker(id int, jobs <-chan int, results chan<- int) {for j := range jobs {fmt.Printf("worker %d started job %d\n", id, j)time.Sleep(time.Second)fmt.Printf("worker %d finished job %d\n", id, j)results <- j * 2}}func main() {jobs := make(chan int, 100)results := make(chan int, 100)for w := 1; w <= 3; w++ {go worker(w, jobs, results)}for j := 1; j <= 9; j++ {jobs <- j}close(jobs)for a := 1; a <= 9; a++ {<-results}}

在这个示例程序中,我们定义了一个名为worker的函数,它模拟了一个工作任务。这个函数接收一个jobs的单向Channel用于接收工作任务,以及一个results的单向Channel用于发送工作结果。当函数接收到一个工作任务时,它会等待一秒钟,然后将工作结果发送到results的Channel中。

main函数中,我们创建了两个Channel:一个jobs的Channel用于发送工作任务,一个results的Channel用于接收工作结果。然后,我们启动了三个Goroutine,并将它们分别分配给worker函数。接下来,我们向jobs的Channel中发送了9个工作任务,并关闭了这个Channel。最后,我们从results的Channel中接收了9个工作结果。

在这个示例程序中,我们使用Channel实现了工作任务的分配和工作结果的收集。通过使用Channel,我们可以轻松地实现Goroutine之间的通信和同步,从而使程序变得简单和高效。

x

热门推荐

go的数据类型-其他数据类型-channel(二) 当前讯息

2023-04

观天下!上海一盗贼入狱后不吃米饭,警察觉得奇怪,查明后立马改判死刑

2023-04

天天快讯:陕西省现代建筑设计研究院有限公司环保所原所长王满堂接受监察调查

2023-04

世界聚焦:八桂大地奋进歌|良好生态成为人民生活质量的增长点

2023-04

流产后如何使子宫快速恢复身体_流产后如何使子宫快速恢复

2023-04

木鱼水心商标被多方抢注

2023-04

推特网友赞中国高铁“舒适宽敞快速准时” 马斯克:是真的!

2023-04

当前速递!1.5g太空礼物!国家航天局:中国向俄罗斯、法国赠送月球样品

2023-04

全球热点!涨停雷达:新冠特效药个股异动 拓新药业触及涨停

2023-04

环球热议:兰州大学第一医院2022年度财务报表审计项目第二次中标公告

2023-04

推荐阅读

山西2021年度发放国家助学贷款逾29亿元 助40万名学生圆大学梦

2021-12

伪造事故赚取“差价” 机动车骗保成诈骗犯罪重灾区

2021-12

内蒙古满洲里新增确诊34例

2021-12

张家口崇礼全力做好冬奥测试赛服务保障工作

2021-12

咖啡、啤酒、盒饭……早出晚归的打工人 寒夜的便利店有故事

2021-12

云南涉疫医疗废物实现“日产日清”

2021-12

对话“贩毒”母亲:不认罪正申诉,盼抗癫痫药物氯巴占可合法购买

2021-12

甘肃省电力投资集团有限责任公司原党委委员、副总经理刘晓黎被开除党籍

2021-12

湖北省委政法委原副巡视员汪宗兴接受审查调查

2021-12

利用游戏平台设线上赌场 江苏一犯罪团伙涉非法牟利数百万元被连锅端

2021-12