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的时候。


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

查看所有标签

猜你喜欢:

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

Programming Amazon Web Services

Programming Amazon Web Services

James Murty / O'Reilly Media / 2008-3-25 / USD 49.99

Building on the success of its storefront and fulfillment services, Amazon now allows businesses to "rent" computing power, data storage and bandwidth on its vast network platform. This book demonstra......一起来看看 《Programming Amazon Web Services》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具