您好,登錄后才能下訂單哦!
Golang是否支持多核cpu?很多人都不太了解,今天小編為了讓大家更加了解Golang,所以給大家總結(jié)了以下內(nèi)容,一起往下看吧。
Golang能使用多核cpu嗎
Golang能使用多核cpu。對于多核編程,go是天生支持,那么我們在什么情況下應(yīng)該用多核心來加速程序呢?
我們來看如下程序:
package main import ( "runtime" "fmt" "sync" "time" ) //定義任務(wù)隊(duì)列 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() //任務(wù)完成,將任務(wù)隊(duì)列中的任務(wù)數(shù)量-1,其實(shí).Done就是.Add(-1) } func main() { //記錄開始時(shí)間 start := time.Now() //設(shè)置最大的可同時(shí)使用的CPU核數(shù)和實(shí)際cpu核數(shù)一致 runtime.GOMAXPROCS(1) for i := 1; i <= 10; i++ { waitgroup.Add(1) //每創(chuàng)建一個(gè)goroutine,就把任務(wù)隊(duì)列中任務(wù)的數(shù)量+1 go xtgxiso(i) } waitgroup.Wait() //Wait()這里會發(fā)生阻塞,直到隊(duì)列中所有的任務(wù)結(jié)束就會解除阻塞 //記錄結(jié)束時(shí)間 end := time.Now() //輸出執(zhí)行時(shí)間,單位為秒。 fmt.Println(end.Sub(start).Seconds()) }
我們可以通過“runtime.GOMAXPROCS(1)”來設(shè)置是單核還是多核心執(zhí)行,對比結(jié)果發(fā)現(xiàn),多核明顯比單核快,所以對于CPU的運(yùn)行上,多核運(yùn)行加速效果是很明顯的。
看完上訴內(nèi)容,你們對Golang是否支持多核cpu大概了解了嗎?如果想了解更多,歡迎關(guān)注億速云行業(yè)資訊頻道哦!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。