您的当前位置:首页>资讯 > 正文

go的数据类型-其他数据类型-channel(二)

  • 2023-04-24 15:16:10 来源:腾讯云


(资料图)

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之间的通信和同步,从而使程序变得简单和高效。

标签:

推荐阅读

go的数据类型-其他数据类型-channel(二)

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

天天快报!强瑞技术(301128):股价5分钟涨速大于5%(04-24)

受短期资金关注,股价快速拉升,5分钟内上涨大于5%以上;资金流向数据,主力资金净流入248 74万元,占总成

今日报丨沃森生物的新冠疫苗何时出头?

近日,沃森生物公布其新型冠状病毒变异株mRNA疫苗的最新进展,Ⅲ期效力临床试验分析结果表明该疫苗具有良好

未按规定披露关联担保 关联交易和股权转让事项,ST海投时任董秘等收证监会行政处罚事决定书|焦点消息

ST海投4月23日公告,近日,公司收到中国证监会《行政处罚决定书(陶琰、朱西川)》,对时任公司监事、合规

深圳机场:正研究推进免税点位优化 将优质商业点位转变为免税店 世界热文

从2月、3月,深圳机场进境免税店销售数据来看,随着国际客流的逐步恢复,免税店经营形势逐步向好,3月份销

猜您喜欢

【版权及免责声明】凡注明"转载来源"的作品,均转载自其它媒体,转载目的在于传递更多的信息,并不代表本网赞同其观点和对其真实性负责。亚洲在线网倡导尊重与保护知识产权,如发现本站文章存在内容、版权或其它问题,烦请联系。 联系方式:8 86 239 5@qq.com,我们将及时沟通与处理。

教育