go goroutine實現素數統計的示例
統計1-120000的素數
1、分析可以通過分段,go協程來實現
2、協程1統計1—30000
3、協程2統計30001—60000
4、協程3統計60001—90000
5、協程4統計90001—120000
如果有更多的數據可以分更多的協程來統計
package main import ( "fmt" "sync" ) var wg sync.WaitGroup func main() { fmt.Println("begin for goroutine") for i := 1; i < 5; i++ { wg.Add(1) go CheckFor(i) } wg.Wait() fmt.Println("this script done!!!!!!!!!") } func CheckFor(n int) { defer wg.Done() for i := (n-1)*30000 + 1; i < n*30000; i++ { flag := true for j := 2; j < i-1; j++ { if i%j == 0 { flag = false } } if flag { fmt.Printf("%d是素數!!!!!!!!!!!!\n", i) } } }
到此這篇關於go goroutine實現素數統計的文章就介紹到這瞭,更多相關go goroutine素數統計內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Go語言中的並發goroutine底層原理
- Go語言如何輕松編寫高效可靠的並發程序
- Go語言線程安全之互斥鎖與讀寫鎖
- 一文掌握Go語言並發編程必備的Mutex互斥鎖
- Golang中的sync包的WaitGroup操作