Golang 协程间的信道
    		       		warning:
    		            这篇文章距离上次修改已过425天,其中的内容可能已经有所变动。
    		        
        		                
                
package main
 
import (
    "fmt"
    "time"
)
 
func worker(id int, c chan int) {
    for {
        // 从信道接收数据,如果信道没有数据可接收,当前协程会被阻塞
        msg := <-c
        fmt.Printf("Worker %d received message: %d\n", id, msg)
        time.Sleep(1 * time.Second) // 模拟工作时间
    }
}
 
func main() {
    // 创建一个信道,协程之间通过这个信道通信
    channel := make(chan int)
 
    // 创建并启动两个协程
    go worker(1, channel)
    go worker(2, channel)
 
    // 主协程负责向信道发送数据,以此来唤醒其他协程
    for i := 0; i < 5; i++ {
        channel <- i // 发送消息
        fmt.Printf("Main sent message: %d\n", i)
        time.Sleep(1 * time.Second) // 模拟等待时间
    }
 
    // 关闭信道,防止发生死锁
    close(channel)
}这段代码创建了一个信道并启动了两个工作协程。主协程循环发送消息到信道,并打印出消息。每个工作协程从信道接收消息,处理任务,并打印出接收到的消息。最后,主协程关闭信道,确保不再有新的消息发送到信道中,并防止工作协程阻塞。
评论已关闭