Golang能使用多核心cpu嗎
Golang能使用多核心cpu。對於多核心編程,go是天生支持,那麼我們在什麼情況下應該用多核心來加速程式呢?
相關推薦:golang教學
我們來看以下程式:
package main import ( "runtime" "fmt" "sync" "time" ) //定义任务队列 var waitgroup sync.WaitGroup func xtgxiso(num int) { for i:=1;i<=1000000000;i++{ num = num+i num = num-i num = num*i num = num/i } waitgroup.Done() //任务完成,将任务队列中的任务数量-1,其实.Done就是.Add(-1) } func main() { //记录开始时间 start := time.Now() //设置最大的可同时使用的CPU核数和实际cpu核数一致 runtime.GOMAXPROCS(1) for i := 1; i <= 10; i++ { waitgroup.Add(1) //每创建一个goroutine,就把任务队列中任务的数量+1 go xtgxiso(i) } waitgroup.Wait() //Wait()这里会发生阻塞,直到队列中所有的任务结束就会解除阻塞 //记录结束时间 end := time.Now() //输出执行时间,单位为秒。 fmt.Println(end.Sub(start).Seconds()) }
我們可以透過「runtime.GOMAXPROCS(1)」來設定是單核心還是多核心執行,對比結果發現,多核心明顯比單核心快,所以對於CPU的運作上,多核心運行加速效果是很明顯的。
PHP中文網,大量程式教學、資料庫管理工具navicat教學,歡迎學習!
以上是Golang能使用多核心cpu嗎的詳細內容。更多資訊請關注PHP中文網其他相關文章!