博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
简单的用go协程统计8000内的素数
阅读量:5261 次
发布时间:2019-06-14

本文共 1323 字,大约阅读时间需要 4 分钟。

package mainimport (    "time"    "fmt")//向管道放入80000个数func createData(size int, intDataChan chan int)  {    if size < 1 {        return    }    for i := 1; i <= size; i++ {        intDataChan <- i    }    close(intDataChan)}func getSuShu(intDataChan chan int, primeChan chan int, exitChan chan bool)  {    var flag bool    for {        time.Sleep(time.Millisecond * 10)        num, ok := <- intDataChan        if !ok {//取不到数据            break        }        flag = true //假设是素数        for i := 2; i <= num /2; i++{            if num % i == 0 {                flag = false //确定不是素数                break            }        }        if flag {            primeChan <- num        }    }    fmt.Println("\n 有一个协程取不到数据,退出")    exitChan <- true //标记退出}func main() {    var maxInt  = 8000    intDataChan := make(chan int, 1000)    primeChan := make(chan int, maxInt / 3)    exitChan := make(chan bool, 4)    go createData(maxInt, intDataChan)    for i := 0; i < 4; i++ {        go getSuShu(intDataChan, primeChan, exitChan)    }    go func() {        for i := 0; i < 4; i++ {            <- exitChan //阻塞直到四个协程都完成工作        }        close(primeChan)//关闭管道    }()    for {        res, ok := <- primeChan        if !ok {            break        }        fmt.Print(res, "  ")    }}

转载于:https://www.cnblogs.com/hirampeng/p/11184288.html

你可能感兴趣的文章
[算法模版]斜率优化
查看>>
语法上的小trick
查看>>
CF461B Appleman and Tree
查看>>
CF219D Choosing Capital for Treeland
查看>>
[算法模版]AC自动机
查看>>
CF1207G Indie Album
查看>>
杂七杂八的小笔记本
查看>>
51Nod1709 复杂度分析
查看>>
[算法模版]树形背包
查看>>
51Nod1353 树
查看>>
[算法模板]SOS DP
查看>>
CF1208F Bits And Pieces
查看>>
CF1215E Marbles
查看>>
手把手教你写一个windows服务 【基于.net】 附实用小工具{注册服务/开启服务/停止服务/删除服务}...
查看>>
.net Core 图片验证码 基于SkiaSharp实现
查看>>
fish redux 个人理解
查看>>
java 笔记一些
查看>>
java面象对向整理
查看>>
mybatis整理笔记
查看>>
java工作记录
查看>>