有缓冲的通道

有缓冲的通道(buffered channel)是一种在接收前能存储一个或多个值的通道。这种类型并不强制要求goroutine之间必须同时完成发送和接收。只有在通道中没有要接收的值时,接收动作才会阻塞。只有在没有缓冲空间时,发送动作才会阻塞。

package main

import (
    "fmt"
    "math/rand"
    "sync"
    "time"
)

const (
    numberGoroutines = 4   //使用goroutine的数量
    taskLoad         = 10    //要处理的工作数量
)

var wg sync.WaitGroup

func init() {
    rand.Seed(time.Now().Unix())
}

func main() {
    tasks := make(chan string, taskLoad)
    wg.Add(numberGoroutines)

   //启动goroutine来处理工作
    for gr := 1; gr <= numberGoroutines; gr++ {
        go worker(tasks, gr)
    }

    //增加一组要处理的工作
    for post := 1; post <= taskLoad; post++ {
        tasks <- fmt.Sprintf("Task:%d", post)
    }

    //指派完要处理的工作后关闭通道
    //所有的goroutine根据通道关闭的条件退出
    close(tasks)

   //等待所有工作完成
    wg.Wait()
}


func worker(tasks chan string, worker int) {
    //通知main函数goroutine返回
    defer wg.Done()

    for {
       //等待要处理的工作,即分配工作
       //通道中没有工作时,goroutine返回
        task, ok := <-tasks
        if !ok {
            //通道为空,已经关闭
            fmt.Printf("worker:%d :shutting Down\n", worker)
            return
        }

        //goroutine开始处理分配到的一个工作
        fmt.Printf("worker:%d:started %s\n", worker, task)

        //随机等待一段时间模拟处理工作
        sleep := rand.Int63n(100)
        time.Sleep(time.Duration(sleep) * time.Millisecond)

        //显示完成了某个工作
        fmt.Printf("worker:%d:completed %s\n", worker, task)
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值