golang channel 堵塞

栏目: Go · 发布时间: 6年前

内容简介:同步操作当在一个协程里面,进行通信的话,其实就是同步操作。(这里通信是指的通过channel进行读取和写入操作,前面代码写入通道,后面代码读取操作)在用for range (或者其他大于通道长度的循环次数),会出现死锁 chan receive deadlock

情况1、同一个协程中,没有关闭通道( no close(chan))

package main
import "fmt"
func main()  {
    ch := make(chan int,3)

    for i:=1; i <= 3; i++ {
        ch <- i
    }

    for data := range ch {
        fmt.Println("echo data :",data)
    }
}

小结

同步操作

当在一个协程里面,进行通信的话,其实就是同步操作。(这里通信是指的通过channel进行读取和写入操作,前面代码写入通道,后面代码读取操作)

在用for range (或者其他大于通道长度的循环次数),会出现死锁 chan receive deadlock

情况2、同一个协程中,关闭通道(close(chan))

package main
import "fmt"
func main()  {
    ch := make(chan int, 3)
    for i := 1; i <= 3; i++ {
        ch <- i
    }
    close(ch)
    for data := range ch {
        fmt.Println("echo data :",data)
    }
    fmt.Println("不堵塞验证")
}

小结

当循环读取数据时,读取遇到关闭通道,会跳出for range 循环。

情况3、协程之间(协程)通信,会出现堵塞

package main
import (
    "fmt"
    "time"
)
func main()  {
    ch := make(chan int,3)
    for i:=1; i <= 3; i++ {
        ch <- i
    }
    go func() {
        for data := range ch {
            fmt.Println("echo data :",data)
        }
                fmt.Println("堵塞在这里") //永远输出不来
    }()

    time.Sleep(time.Second) // 用于调试,防止子协程还没有执行,就直接退出。
}

小结

会出现堵塞,子协程会一直堵塞,直到接收到关闭channel的时候。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

流量的秘密

流量的秘密

(英)Brian Clifton / 钟镭 / 人民邮电出版社 / 2010-2 / 45.00元

你对自己的网站有足够的了解吗?你知道自己网站的真实影响力和竞争力吗?你在想尽办法留住你的访客吗?《流量的秘密:Google Analytics网站分析与优化技巧》将运用最新的网络计量学方法,教你获取真正有价值的信息。 哪种市场营销活动最有成效?如何量化这些效果?应该从哪些衡量指标进行追踪?《流量的秘密:Google Analytics网站分析与优化技巧》介绍的Google Analytics......一起来看看 《流量的秘密》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

MD5 加密
MD5 加密

MD5 加密工具

SHA 加密
SHA 加密

SHA 加密工具