首页后端开发其他后端知识Golang中什么时候使用多核cpu加速程序

Golang中什么时候使用多核cpu加速程序

时间2024-03-26 23:08:03发布访客分类其他后端知识浏览1019
导读:今天这篇给大家分享的知识是“Golang中什么时候使用多核cpu加速程序”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“Golang中什么时候使用多核cpu加速程序”文章能帮助大家解决问题。...
今天这篇给大家分享的知识是“Golang中什么时候使用多核cpu加速程序”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“Golang中什么时候使用多核cpu加速程序”文章能帮助大家解决问题。


Golang能使用多核cpu吗

Golang能使用多核cpu。对于多核编程,go是天生支持,那么我们在什么情况下应该用多核心来加速程序呢?

我们来看如下程序:

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的运行上,多核运行加速效果是很明显的。


现在大家对于Golang中什么时候使用多核cpu加速程序的内容应该都清楚了吧,希望大家阅读完这篇文章能有所收获。最后,想要了解更多Golang中什么时候使用多核cpu加速程序的知识,欢迎关注网络,网络将为大家推送更多相关知识点的文章。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: Golang中什么时候使用多核cpu加速程序
本文地址: https://pptw.com/jishu/653819.html
什么是gulp?如何使用? node里面全局包是什么,全局安装模块要注意哪些

游客 回复需填写必要信息