内容简介:pips/pip_prime.gofanin2.go程序输出如下,可知相比于不使用扇入写法,效率从25s提升至5s,提升了五分之四。
pips/pip_prime.go
package pips
import (
"sync"
)
type PrimePip struct {
}
func NewPrimePip() *PrimePip {
primePip := &PrimePip{}
return primePip
}
func (primePip *PrimePip) RepeatFn(
done <-chan interface{},
fn func() interface{},
) <-chan interface{} {
valueStream := make(chan interface{})
go func() {
defer close(valueStream)
for {
select {
case <-done:
return
case valueStream <- fn():
}
}
}()
return valueStream
}
func (primePip *PrimePip) Take(
done <-chan interface{},
valueStream <-chan interface{},
num int,
) <-chan interface{} {
takeStream := make(chan interface{})
go func() {
defer close(takeStream)
for i := 0; i < num; i++ {
select {
case <-done:
return
case takeStream <- <-valueStream:
}
}
}()
return takeStream
}
func (primePip *PrimePip) ToInt(
done <-chan interface{},
valueStream <-chan interface{},
) <-chan int {
intStream := make(chan int)
go func() {
defer close(intStream)
for v := range valueStream {
select {
case <-done:
return
case intStream <- v.(int):
}
}
}()
return intStream
}
func (primePip *PrimePip) PrimeFinder(
done <-chan interface{},
intStream <-chan int,
) <-chan interface{} {
primeStream := make(chan interface{})
go func() {
defer close(primeStream)
for integer := range intStream {
integer -= 1
prime := true
for divisor := integer - 1; divisor > 1; divisor-- {
if integer%divisor == 0 {
prime = false
break
}
}
if prime {
select {
case <-done:
return
case primeStream <- integer:
}
}
}
}()
return primeStream
}
func (primePip *PrimePip) FanIn(
done <-chan interface{},
channels ...<-chan interface{},
) <-chan interface{} {
var wg sync.WaitGroup
multiplexedStream := make(chan interface{})
multiplexed := func(c <-chan interface{}) {
defer wg.Done()
for i := range c {
select {
case <-done:
return
case multiplexedStream <- i:
}
}
}
wg.Add(len(channels))
for _, c := range channels {
go multiplexed(c)
}
go func() {
wg.Wait()
close(multiplexedStream)
}()
return multiplexedStream
}
fanin2.go
// fanin2
package main
import (
"fanin2/pips"
"fmt"
"math/rand"
"runtime"
"time"
)
func main() {
done := make(chan interface{})
defer close(done)
start := time.Now()
rand := func() interface{} {
return rand.Intn(50000000)
}
primeP := pips.NewPrimePip()
randIntStream := primeP.ToInt(done, primeP.RepeatFn(done, rand))
numFinders := runtime.NumCPU()
fmt.Printf("Spinning up %d prime Finders \n", numFinders)
finders := make([]<-chan interface{}, numFinders)
fmt.Println("Primes:")
for i := 0; i < numFinders; i++ {
finders[i] = primeP.PrimeFinder(done, randIntStream)
}
for prime := range primeP.Take(done, primeP.FanIn(done, finders...), 10) {
fmt.Printf("\t%d \n", prime)
}
fmt.Printf("Search Took: %v \n", time.Since(start))
}
程序输出如下,可知相比于不使用扇入写法,效率从25s提升至5s,提升了五分之四。
image.png
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 关于质数(素数)
- python素数筛选法浅析
- 落格输入法是如何处理按键消息的
- 使用goroutine/channel求素数问题
- CRC32(第12个梅森素数)
- 搜狗智能联想输入法,背后的运维又是如何智能的?
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
函数式算法设计珠玑
Richard Bird / 苏统华、孙芳媛、郝文超、徐琴 / 机械工业出版社 / 2017-4-1 / 69.00
本书采用完全崭新的方式介绍算法设计。全书由30个珠玑构成,每个珠玑单独列为一章,用于解决一个特定编程问题。这些问题的出处五花八门,有的来自游戏或拼图,有的是有趣的组合任务,还有的是散落于数据压缩及字串匹配等领域的更为熟悉的算法。每个珠玑以使用函数式编程语言Haskell对问题进行描述作为开始,每个解答均是诉诸于函数式编程法则从问题表述中计算得到。本书适用于那些喜欢学习算法设计思想的函数式编程人员、......一起来看看 《函数式算法设计珠玑》 这本书的介绍吧!
SHA 加密
SHA 加密工具
XML、JSON 在线转换
在线XML、JSON转换工具