关闭一个已关闭的chan会发生什么

如关闭一个已关闭的chan会如何,有缓存和无缓存的区别是什么?

会发生panic: close of closed channel

只能关闭双向channel或者发送channel

关闭后向关闭的channel发送数据会引起pannic

而向关闭的channel读取数据将会读取完最后一个值后再返回一个0值

channel := make(chan int, 5)
channel <- 5
channel <- 4
channel <- 3
close(channel)
value, ok := <-channel

println(value, ok)

value, ok = <-channel
println(value, ok)

value, ok = <-channel
println(value, ok)

value, ok = <-channel
println(value, ok)


//打印结果
//5 true
//4 true
//3 true
//0 false

Go 语言中的通道(channel)是一种用于在不同的 goroutine 之间进行通信和同步的机制。通道可以用于在 goroutine 之间传递数据,并确保这些 goroutine 之间的同步,从而避免了竞态条件的发生。在以下情况下,您可以使用通道: 1. 用于在不同的 goroutine 之间传递数据。 2. 用于控制 goroutine 的执行顺序。 3. 用于限制并发访问共享资源的数量。 下面是几个通道的应用场景: 1. 实现多个 goroutine 之间的同步和互斥。 2. 通过通道传递数据,实现 goroutine 之间的通信。 3. 控制 goroutine 的执行顺序,实现任务的分发和协调。 4. 使用通道作为信号量,限制并发访问共享资源的数量。 下面是一个使用通道实现并发的例子: ```go package main import ( "fmt" "time" ) func worker(id int, jobs <-chan int, results chan<- int) { for j := range jobs { fmt.Printf("worker %d started job %d\n", id, j) time.Sleep(time.Second) fmt.Printf("worker %d finished job %d\n", id, j) results <- j * 2 } } func main() { jobs := make(chan int, 100) results := make(chan int, 100) for w := 1; w <= 3; w++ { go worker(w, jobs, results) } for j := 1; j <= 9; j++ { jobs <- j } close(jobs) for a := 1; a <= 9; a++ { <-results } } ``` 在上面的例子中,我们定义了两个通道 `jobs` 和 `results`,`jobs` 通道用于传递任务,`results` 通道用于传递任务的结果。我们创建了 3 个 goroutine 来处理任务,每个 goroutine 从 `jobs` 通道中读取任务,处理完后将结果发送到 `results` 通道中。在主函数中,我们将任务发送到 `jobs` 通道中,并从 `results` 通道中读取结果。当所有任务都处理完成后,我们关闭 `jobs` 通道,以通知所有 goroutine 工作已经完成。 以上是通道的基本应用,希望对您有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值