Go实现线程池

本文通过代码讲解如何实现一个线程池。代码及注释如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值