继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

go channel的常规用法

holdtom
关注TA
已关注
手记 1846
粉丝 240
获赞 991

循环获取channel

func get(data chan int){    for v,ok := range chan{        if !ok{            //channel 已经关闭
            break
        }        // do something with v
    }
}

如果需要停止使用channel,需要手动将channel关闭

close(data)

关闭后的channel还能获取其中存在的数据,但是不能再增加数据。数据取完后ok值为false。

channel关闭的判断

ch = make(chan int, 10)//....some codeselect{    case r,ok := <- ch:    if !ok  {        //通道已空 并且已经关闭
    }
}

向有缓存的channel传数据,满了就停止,不阻塞

ch = make(chan int, 10)

Fill: //为循环设置tagfor{    select {        case ch <- 1:        default:            break Fill
    }
}

for循环必须设置tag,不然select中的break无法停止外部循环,会一直执行default,陷入死循环。

//这段代码会陷入死循环中,每次都执行defaultfor{    select{    case <- time.After(10*time.Second):    default:        break
    }
}

超时的使用

select{    case job <- jobList    case <- time.After(10 * time.Second):    //10秒后做超时处理}

原文



打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP