# Go 并行通道Channel
Channel是连接并行协程(goroutine)的通道。你可以向一个通道写入数据然后从另外一个通道读取数据。
```go
package main
import "fmt"
func main() {
// 使用`make(chan 数据类型)`来创建一个Channel
// Channel的类型就是它们所传递的数据的类型
messages := make(chan string)
// 使用`channel <-`语法来向一个Channel写入数据
// 这里我们从一个新的协程向messages通道写入数据ping
go func() { messages <- "ping" }()
// 使用`<-channel`语法来从Channel读取数据
// 这里我们从main函数所在的协程来读取刚刚写入
// messages通道的数据
msg := <-messages
fmt.Println(msg)
}
```
运行结果
```
ping
```
当我们运行程序的时候,数据ping成功地从一个协程传递到了另外一个协程。
默认情况下,协程之间的通信是同步的,也就是说数据的发送端和接收端必须配对使用。Channel的这种特点使得我们可以不用在程序结尾添加额外的代码也能够获取协程发送端发来的信息。因为程序执行到`msg:=<-messages`的时候被阻塞了,直到获得发送端发来的信息才继续执行。
- 版权
- 内容
- Go常量
- Go变量
- Go 数值
- Go 数组
- Go 字典
- Go 函数定义
- Go 方法
- Go 结构体
- Go 闭包函数
- Go 接口
- Go 字符串操作函数
- Go 字符串格式化
- Go 自定义排序
- Go Base64编码
- Go Defer
- Go Exit.md
- Go for循环
- Go if..else if..else 条件判断
- Go JSON支持
- Go Line Filters
- Go 状态协程
- Go Panic
- Go range函数
- Go SHA1 散列
- Go String与Byte切片之间的转换
- Go Switch语句
- Go URL解析
- Go 遍历通道
- Go 并行功能
- Go 并行通道Channel
- Go 超时
- Go 错误处理
- Go 打点器
- Go 递归函数
- Go 读取文件
- Go 工作池
- Go 关闭通道
- Go 函数多返回值
- Go 函数回调
- Go 函数命名返回值
- Go 互斥
- Go 环境变量
- Go 集合功能
- Go 计时器
- Go 进程触发
- Go 进程执行
- Go hello world
- Go 可变长参数列表
- Go 命令行参数
- Go 命令行参数标记
- Go 排序
- Go 切片
- Go 请求处理频率控制
- Go 时间
- Go 时间戳
- Go 时间格式化和解析
- Go 数字解析
- Go 随机数
- Go 通道的同步功能
- Go 通道方向
- Go 通道缓冲
- Go 通道选择Select
- Go 写入文件
- Go 信号处理
- Go 原子计数器
- Go 正则表达式
- Go 指针