Go语言中channel用于goroutine间通信,基于CSP模型,通过make创建,分无缓冲和有缓冲两种;发送接收使用

Go语言中的channel是实现goroutine之间通信和同步的重要机制。它基于CSP(Communicating Sequential Processes)模型设计,通过发送和接收值来传递数据,而不是共享内存。
Channel的定义与声明
Channel是一种引用类型,使用 make 函数创建。其基本语法如下:
chanType := make(chan Type) // 无缓冲channelchanType := make(chan Type, size) // 有缓冲channel
其中 Type 是channel传输的数据类型,size 表示缓冲区大小。若size为0,则为无缓冲channel,发送和接收操作必须同时就绪才能完成。
例如:
立即学习“go语言免费学习笔记(深入)”;
ch := make(chan int) // 无缓冲int型channelbufferedCh := make(chan string, 5) // 缓冲区为5的string型channel
Channel的基本操作:发送与接收
向channel发送数据使用 操作符,格式为:
ch从channel接收数据同样使用 ,可带或不带返回值:
value := value, ok :=对于无缓冲channel,发送操作会阻塞,直到另一个goroutine执行对应的接收操作。缓冲channel在缓冲区未满时允许非阻塞发送,接收则在有数据时立即返回。
酷纬企业网站管理系统Kuwebs是酷纬信息开发的为企业网站提供解决方案而开发的营销型网站系统。在线留言模块、常见问题模块、友情链接模块。前台采用DIV+CSS,遵循SEO标准。 1.支持中文、英文两种版本,后台可以在不同的环境下编辑中英文。 3.程序和界面分离,提供通用的PHP标准语法字段供前台调用,可以为不同的页面设置不同的风格。 5.支持google地图生成、自定义标题、自定义关键词、自定义描
关闭Channel与范围遍历
使用 close 函数显式关闭channel:
close(ch)关闭后不能再向channel发送数据,但可以继续接收,直到所有已发送数据被取完,后续接收返回零值。
常配合 for-range 遍历channel,自动处理接收和关闭状态:
for v := range ch {fmt.Println(v)
}
这种方式适用于生产者-消费者模型,当生产者调用 close(ch) 后,range循环会自动退出。
单向Channel的使用场景
Go支持声明只读或只写的channel,用于函数参数限定行为,增强类型安全:
func sendOnly(ch chan ch }func recvOnly(ch fmt.Println( }
实际传参时,双向channel可隐式转换为单向类型,防止误用。
基本上就这些。掌握channel的定义、收发控制、关闭机制和单向约束,就能有效编写并发安全的Go程序。注意避免向已关闭的channel发送数据,会导致panic。









