• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Go实现线程池

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文通过代码讲解如何实现一个线程池。代码(来自https://gobyexample.com/)及注释如下:

package main

 

import "fmt"

import "time"

 

//这个是工作线程,处理具体的业务逻辑,将jobs中的任务取出,处理后将处理结果放置在results中。

func worker(id int, jobs <-chan int, results chan<- int) {

for j := range jobs {

fmt.Println("worker", id, "processing job", j)

time.Sleep(time.Second)

results <- j * 2

}

}

 

func main() {

 

//两个channel,一个用来放置工作项,一个用来存放处理结果。

jobs := make(chan int, 100)

results := make(chan int, 100)

 

// 开启三个线程,也就是说线程池中只有3个线程,实际情况下,我们可以根据需要动态增加或减少线程。

for w := 1; w <= 3; w++ {

go worker(w, jobs, results)

}

 

// 添加9个任务后关闭Channel

// channel to indicate that's all the work we have.

for j := 1; j <= 9; j++ {

jobs <- j

}

close(jobs)

 

//获取所有的处理结果

for a := 1; a <= 9; a++ {

<-results

}

}

 

 

输出结果:

worker 1 processing job 1

worker 2 processing job 2

worker 3 processing job 3

worker 1 processing job 4

worker 3 processing job 5

worker 2 processing job 6

worker 1 processing job 7

worker 2 processing job 8

worker 3 processing job 9

 

从中可以看出,多个线程轮流处理了9个任务。

通过这个例子,我们可以学习到:

1、GO中多线程应用开发非常简单。

2、Channel是不同线程间数据交互的利器。 上面的例子中,主线程向jobs中写数据,三个工作线程同时从一个Channel中取数据。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
转:Go语言的冷知识发布时间:2022-07-10
下一篇:
Go语言从入门到实战 笔记06发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap