首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Go程序例子(30):缓存通道

Go程序例子(30):缓存通道

原创
作者头像
用户11078756
发布2024-12-17 16:54:30
发布2024-12-17 16:54:30
1240
举报
文章被收录于专栏:go程序例子go程序例子

默认情况下,通道是 无缓冲 的,这意味着它们只有在有相应的接收者(<-chan)准备好接收发送的值时,才会接受发送操作(chan <-)。如果没有接收者准备好接收,发送操作会阻塞,直到接收者准备好。 而 有缓冲的通道 可以接受一定数量的值,即使没有立即的接收者。这些值会被保存在通道的缓冲区中,直到有接收者接收这些值或者缓冲区被填满。

代码语言:go
复制
package main

import "fmt"

func main() {
	// 在下面的代码中,我们创建了一个能够缓冲最多 2 个字符串值的通道。这个缓冲区允许我们在没有立即接收者的情况下发送两个值,而不会阻塞,直到缓冲区满。
    messages := make(chan string, 2)
	// 由于这个通道是 **有缓冲的**,我们可以在没有相应的并发接收操作的情况下,向通道发送这些值。也就是说,即使没有立即的接收者准备好接收,发送的值会被存储在通道的缓冲区中,直到接收者准备好接收。
    messages <- "buffered"
    messages <- "channel"
	// 稍后我们可以像往常一样接收这两个值。
    fmt.Println(<-messages)
    fmt.Println(<-messages)
}

运行结果:

代码语言:javascript
复制
$ go run channel-buffering.go 
buffered
channel

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档