# 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 指針