Go并发模式之如何很好很强大读取channel(orDone函数)

我需要从 一个channel中读取数据; 这个channel 我不能对他行为(如: 什么时候被close(),被取消)做出假设,
可以 range 读取(但是 总要判断 true 才能使用他返回的值,不爽!);
for val := range myChan{
   //用val 执行某些操作
}
可以使用 select 来包装 读操作如下:
loop:
for {
   select{
      case <- done:
         break loop
      case maybeVal, ok := <- myChan:
         if ok == false{
            return //这 或许从 for 循环中退出
         }
         //用 val 执行某些操作
   }
}


 */
// 对 这种处理就很细致全面了,可以很好很强大的 控制读取chan了。
//完整代码如下:(封装成 函数)
var orDone = func(done, c<- chan interface{}) <- chan interface{} {
	valStream := make(chan interface{})
	go func() {
		defer close(valStream)
		for{
			select {
			case <-done :
				return
			case v, ok := <-c:
				if ok == false{
					return
				}
				select{
				case valStream <- v:
				case <-done:
				}
			}
		}

	}()
	return valStream
}
使用 orDone ; 我又可以 回到简单的循环了 如下:

for val := range orDone(done, myChan){
   //用 val 执行某些操作。
}

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值