加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

Golang:无缓冲和单向channel

发布时间:2020-12-16 19:18:05 所属栏目:大数据 来源:网络整理
导读:简介 初学golang很容易混淆无缓冲的chan和只有一个元素的chan,认为这两个是一回事,其实是完全不同的,make(chan int) 是同步的,只能同时读写,没有读写会一直阻塞;make(chan int,1)是异步的,第一个入队的不会阻塞 c1:= make ( chan int ) 无缓冲c2:= ma

简介

初学golang很容易混淆无缓冲的chan和只有一个元素的chan,认为这两个是一回事,其实是完全不同的,make(chan int) 是同步的,只能同时读写,没有读写会一直阻塞;make(chan int,1)是异步的,第一个入队的不会阻塞

c1:=make(chan int)        无缓冲
c2:=make(chan int,1)      有缓冲

code

package main

import (
    "fmt"
    "sync"
)

var wt sync.WaitGroup

func OutChan(noBufChan <-chan int) {

    //chan关闭后for退出循环,否则会死循环
    for v := range noBufChan {
        fmt.Println(v)
    }

    wt.Done()
}

func InChan(noBufChan chan<- int) {

    for i := 0; i < 5; i++ {
        noBufChan <- i
    }
    //v := <-noBufChan //invalid operation: <-noBufChan (receive from send-only type chan<- int)
    close(noBufChan)
    wt.Done()
}

func main() {

    wt.Add(2)

    //无缓冲的chan,同步方式,有读才能写入
    var noBufChan = make(chan int)

    go InChan(noBufChan)
    go OutChan(noBufChan)

    wt.Wait()

    fmt.Println("goroute全部退出")
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读