美文网首页
golang对于 nil通道 close通道你所不知道的神器特性

golang对于 nil通道 close通道你所不知道的神器特性

作者: kingeasternsun | 来源:发表于2017-07-06 11:38 被阅读0次

    英文原文

    C1. 以下操作会引起panic

    • P1. Closing the nil channel.

    实例:

    func C1P1() {
        var ch chan int
        close(ch)
    }
    
    

    结果

    panic: close of nil channel
    
    goroutine 1 [running]:
    panic(0x458300, 0xc82000a170)
            /home/wdy/go/src/runtime/panic.go:464 +0x3e6
    main.main()
            /home/wdy/learn/program-learn/golang/learnchannel.go:27 +0x1e
    exit status 2
    
    • P2. Closing a closed channel.

    实例:

    func C1P2() {
        ch := make(chan int, 0)
        close(ch)
        close(ch)
    }
    

    结果:

    panic: close of closed channel
    
    goroutine 1 [running]:
    panic(0x458300, 0xc82000a170)
            /home/wdy/go/src/runtime/panic.go:464 +0x3e6
    main.main()
            /home/wdy/learn/program-learn/golang/learnchannel.go:27 +0x4d
    exit status 2
    
    • P3. Sending on a closed channel.

    实例:

    func C1P3() {
        ch := make(chan int, 0)
        close(ch)
        ch <- 2
    }
    

    结果:

    panic: send on closed channel
    
    goroutine 1 [running]:
    panic(0x458300, 0xc82000a170)
            /home/wdy/go/src/runtime/panic.go:464 +0x3e6
    main.main()
            /home/wdy/learn/program-learn/golang/learnchannel.go:23 +0x6c
    exit status 2
    

    C2. 作为接受者的goroutine不要关闭channel,否则 发送者未来往这个channel发送数据时会panic

    C3. 如果一个channel有多个发送者,发送者就不要关闭通道或者最后一个发送数据的goroutine来关闭通道。

    Last one sender to leave, turns off the lights, which can be controlled by a atomic int

    C4. 对于不再使用的通道不必显示关闭。如果没有goroutine引用这个通道,这个通道就会被垃圾回收。

    注意如果需要把关闭通道作为一个控制信号告知其他goroutine没有更多数据的情况下,需要显示关闭。讨论

    C5. 通道和select搭配最佳。

    C6. 如果在两个goroutine中需要一个双向沟通,考虑使用两个单独的单向通道。这样两个通道就可以通过调用close的方法来告知对方通讯终止。

    C7. 如果通道没有负责读取的goroutine的时候,那么发送者就可能会永远阻塞在该通道上。

    C8. 当设计一个goroutine通过channel来提供服务的时候,在某个时刻这个goroutine不再需要了,要仔细考虑goroutine应该怎么结束。否则这个不再使用的goroutine会服务一个不受监管的channel。

    C9. Dave Cheney's Four Channel Axioms :

    • A1. 对一个 nil channel执行发送操作会一直阻塞。

    实例:

    func C9A1() {
        fmt.Println("C9A1")
        var ch chan int
        ch <- 2
    }
    

    结果:

    C9A1
    fatal error: all goroutines are asleep - deadlock!
    
    goroutine 1 [chan send (nil chan)]:
    main.C9A1()
            /home/wdy/learn/program-learn/golang/learnchannel.go:27 +0xf9
    main.main()
            /home/wdy/learn/program-learn/golang/learnchannel.go:37 +0x14
    exit status 2
    

    发送:

    func C9A2() {
        fmt.Println("C9A2")
        var ch chan int
        <-ch
    }
    

    结果:

    C9A2
    fatal error: all goroutines are asleep - deadlock!
    
    goroutine 1 [chan receive (nil chan)]:
    main.C9A2()
            /home/wdy/learn/program-learn/golang/learnchannel.go:33 +0xec
    main.main()
            /home/wdy/learn/program-learn/golang/learnchannel.go:38 +0x14
    exit status 2
    
    • A3. 发送到关闭的channel会引起panic

    • A4. 从关闭的cannel读操作,会立刻返回数据0值。

    C10. 'select' 从来不会选择阻塞的case,意思就是如果select的多个case都阻塞了,那么当前goroutine就会阻塞在select上。

    后记

    之前一直在CSDN上写文章,后面会逐步转换到简书上,还请大家多多支持。

    相关文章

      网友评论

          本文标题:golang对于 nil通道 close通道你所不知道的神器特性

          本文链接:https://www.haomeiwen.com/subject/tzlhhxtx.html