【golang】go-channel-goroutine实践2
2016-08-16 15:30
302 查看
需求:获取数组数据,对数据的原始数据逐个进行处理,后返回处理完的数据
目标:对列表数据进行逐个goroutine并发处理,再用select整合,返回数据
目标:对列表数据进行逐个goroutine并发处理,再用select整合,返回数据
type money_per struct{ id int name string money float64 } type MoneyHandler interface { BatchDeal(m money_per) } type MoneyHandlerImpl struct { } func getMoneyHandler() MoneyHandler { return &MoneyHandlerImpl{} } var moneyPers = make([]money_per, 10) var mchan = make(chan money_per, 100) //初始化 func init() { for i :=0; i<10 ;i++ { var moneyPer = money_per{i, "ww"+strconv.Itoa(i), float64(i)} moneyPers[i] = moneyPer } } //业务处理 func (monnryHandler MoneyHandlerImpl)BatchDeal(m money_per) { m.money +=11.0 time.Sleep(time.Second) mchan <- m } func main() { fmt.Println(moneyPers, cap(moneyPers), len(moneyPers)) t1 := time.Now() moneyHandler := getMoneyHandler() for mm := range moneyPers{ fmt.Println(moneyPers[mm]) go moneyHandler.BatchDeal(moneyPers[mm]) } elapsed0 := time.Since(t1) fmt.Println("App elapsed0: ", elapsed0) rm := make([]money_per,10) for i :=0; i<10 ;i++ { //m := <-mchan //rm[m.id] = m //fmt.Println(m) select { // select轮询机制 case m := <- mchan: fmt.Println(m) rm[m.id] = m } } elapsed := time.Since(t1) fmt.Println("App elapsed: ", elapsed) }
相关文章推荐
- 【golang】go-channel-goroutine实践1
- go语言之行--golang核武器goroutine调度原理、channel详解
- Goroutine + Channel 实践
- Goroutine + Channel 实践
- golang语言并发与并行——goroutine和channel的详细理解
- go 使用 goroutine channel 通信
- Golang原理之goroutine与channel
- golang语言并发与并行——goroutine和channel的详细理解(一)
- golang的goroutine与channel
- 浅谈Go Channel 高级实践
- 一个Golang例子:for + goroutine + channel
- Goroutine + Channel 实践
- golang语言并发与并行——goroutine和channel的详细理解(二)
- Go基础--goroutine和channel
- golang语言并发与并行——goroutine和channel的详细理解(一)
- golang语言并发与并行——goroutine和channel的详细理解(三)
- Golang通过Goroutine+Channel指定同时下载的数量
- Goroutine + Channel 实践
- golang语言并发与并行——goroutine和channel的详细理解(二)
- golang语言并发与并行——goroutine和channel的详细理解