golang channel 堵塞

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

内容简介:同步操作当在一个协程里面,进行通信的话,其实就是同步操作。(这里通信是指的通过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的时候。


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

查看所有标签

猜你喜欢:

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

Practical Django Projects, Second Edition

Practical Django Projects, Second Edition

James Bennett / Apress / 2009 / 44.99

Build a django content management system, blog, and social networking site with James Bennett as he introduces version 1.1 of the popular Django framework. You’ll work through the development of ea......一起来看看 《Practical Django Projects, Second Edition》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

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

HEX HSV 互换工具