【go】通道 Channel

通道(channel)表示传递数据的一种数据结构。

通道可用于两个 goroutine 之间通过传递一个指定类型的值来同步运行和通讯。操作符 <- 用于指定通道的方向,发送或接收。如果未指定方向,则为双向通道。

声明通道

 //  默认情况下,通道是不带缓冲区的
 // 发送端发送数据,同时必须有接收端接收相应的数据。
 ch := make(chan struct{})
// 声明带缓冲区的通道,通过 make 的第二个参数指定缓冲区大小
ch :=make(chan struct{},10)

注意:带缓冲区的通道允许发送端和接收端的数据传递处于异步状态,即发送端发送的数据可以放在缓冲区里面,等待接收端去获取数据,而不是立刻需要接收端去获取数据。但是缓冲区大小受限,必须有接收端来接收数据,否则缓冲区一满会导致数据发送端就无法再发送数据。

关闭通道

close(ch)

struct{}是结构体类型的代表
struct{}{}是结构体的值,本身为零值,读取close的channel返回零值

遍历通道

// 若通道接收不到数据后,ok为 false
v, ok := <-ch
package main
 
import (
        "fmt"
)
 
func fibonacci(n int, c chan int) {
        x, y := 0, 1
        for i := 0; i < n; i++ {
                c <- x
                x, y = y, x+y
                fmt.Println("aaa")
        }
        close(c)
}
 
func main() {
        c := make(chan int, 10)
        go fibonacci(cap(c), c)
        // range 函数遍历每个从通道接收到的数据,因为 c 在发送完 10 个
        // 数据之后就关闭了通道,所以这里我们 range 函数在接收到 10 个数据
        // 之后就结束了。如果上面的 c 通道不关闭,那么 range 函数就不
        // 会结束,从而在接收第 11 个数据的时候就阻塞了。
        for i := range c {
                fmt.Println(i)
        }
}

通道数据读写

// 通道数据写入
ch <- struct{}{}

//通道数据读取
var data struct{}
 data  = <-ch

常用场景

// 推荐使用缓冲区写法,channel一定要先make
ch := make(chan struct{},1)

ch <- struct{}{}

for {
		select {
		case <-ch:
	    // do something
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值