go的数据类型-其他数据类型-channel(二)-全球资讯
以下是一个使用Channel的示例程序,该程序创建了两个Goroutine,并使用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之间的通信和同步,从而使程序变得简单和高效。
标签:
以下是一个使用Channel的示例程序,该程序创建了两个Goroutine,并使用Channel在它们之间进行通信和同步。
何卓彦(舞台一排左)在百年古寺东景缘演出 清脆明亮的口琴声中,融入电钢琴、吉他、贝斯和鼓点。一曲爵士
水系镁空气电池具有理论能量密度高、环境友好、安全性高、成本低和贮存寿命长的特点,是一种理想的应急储备
南象投资集团|专注中俄贸易俄罗斯进口老米乐啤酒系列俄罗斯进口老米乐啤酒系列俄罗斯进口啤酒为什么这么受
21日,在第23个世界知识产权日即将来临之际,省知识产权局、鹤岗市政府联合主办的“黑龙江省石墨产业专...
【美国加州洛杉矶县近95万升污水泄漏当地海滩被迫关闭】据美国有线电视新闻网当地时间4月22日报道,美国加
4月21日,和元生物精准医疗产业基地在上海市临港新片区开业。该项目总投资约15亿元,总建筑面积约77000平方
4月21日,“失业女生摆摊一天卖5块崩溃痛哭”话题登上热搜第一,话题阅读量达1亿+。女生在失业90天后,...
1、打开苹果手机,点击桌面设置,如下图所示:2、进入设置。2、点击最上方AppleID账号进入,如下图所示:3
1、查询手机的S N号查询的方法有两种:方法一:手机的外包装盒标签标注有S N号。2、方法二:手机关机,取下