golang 多协程处理任务

本文介绍了一个使用Go语言实现的简单并发模型案例。该案例通过创建多个协程来模拟并发请求处理,并展示了如何利用channel进行任务分发和结果收集。文章详细解释了从任务分配到结果收集的整个流程。
package main
 
import (
	"fmt"
	"runtime"
)
 
var workers = runtime.NumCPU()
 
type result struct {
	jobname    string
	resultcode int
	resultinfo string
}
 
type job struct {
	jobname string
	results chan<- result
}
 
func main() {
	jobnames := []string{"1", "2", "3", "4", "5", "6", "7", "8"}
	dorequest(jobnames)
}
 
func dorequest(jobnames []string) {
 
	// 定义需要的channels切片
	jobs := make(chan job, workers)
	results := make(chan result, len(jobnames))
	done := make(chan struct{}, workers)
 
 	/**
 	 * 把任务写入 JobCh通道 
 	 **/
 	go func( jobs chan <- job, jobnames[]string, results chan <- result){
 		for _, jobname := range jobnames {
			jobs <- job{jobname, results}
		}
		close(jobs)
 	}( jobs, jobnames, results)

 	/**
 	 * 开启n个协程处理任务
 	 **/
	for i := 0; i < workers; i++ {
		go func( done chan <- struct{}, jobs <- chan job){
			for job := range jobs {
				job.do()
			}
			done <- struct{}{}
		}( done, jobs)
	}
	
	/**
	 * 查看任务是否完成
	 **/
	go func( done <- chan struct{}, results chan result){
		for i := 0; i < workers; i++ {
			<-done
		}
		close(results)
	}( done, results)

	/**
	 * 取出结果
	 **/
	for result := range results {
		fmt.Printf("done: %s,%d,%s\n", result.jobname, result.resultcode, result.resultinfo)
	}
}
func (job job) do() {
	fmt.Printf("... doing work in [%s]\n", job.jobname)
 
	// 模拟处理结果
	if job.jobname == "8" {
		job.results <- result{job.jobname, 0, "ok"}
	} else {
		job.results <- result{job.jobname, -1, "error"}
	}
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值