golang 分别用channel的有缓冲和无缓冲 实现信息的接受和传递
在 Go 中,channel 可以是有缓冲的或无缓冲的。无缓冲 channel 在发送和接收操作上是同步的,而有缓冲 channel 则允许异步发送和接收。
下面是一个简单的示例,演示了如何使用无缓冲 channel 在两个 goroutine 之间传递信息
ch := make(chan string) // 创建一个无缓冲 channel
// 启动一个新的 goroutine
go func() {
msg := <-ch // 从 channel 中接收信息
fmt.Println(msg) // 输出接收到的信息
}()
ch <- "hello" // 向 channel 发送信息
在上面的代码中,我们创建了一个无缓冲的 string 类型的 channel,然后启动了一个新的 goroutine,在这个 goroutine 中,我们从 channel 中接收信息并输出。最后,我们向 channel 发送了一个字符串 “hello”。运行这段代码,你会看到输出 “hello”。
下面是一个简单的示例,演示了如何使用有缓冲 channel 在两个 goroutine 之间传递信息。
ch := make(chan string, 1) // 创建一个有缓冲 channel
// 启动一个新的 goroutine
go func() {
msg := <-ch // 从 channel 中接收信息
fmt.Println(msg) // 输出接收到的信息
}()
ch <- "hello" // 向 channel 发送信息
在上面的代码中,我们创建了一个有缓冲的 string 类型的 channel,容量为 1。然后启动了一个新的 goroutine,在这个 goroutine 中,我们从 channel 中接收信息并输出。最后,我们向 channel 发送了一个字符串 “hello”。运行这段代码,你会看到输出 “hello”。