golang能使用多核cpu吗
golang能使用多核cpu。对于多核编程,go是天生支持,那么我们在什么情况下应该用多核心来加速程序呢?
相关推荐:golang教程
我们来看如下程序:
package mainimport ( "runtime" "fmt" "sync" "time")//定义任务队列var waitgroup sync.waitgroupfunc 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的运行上,多核运行加速效果是很明显的。
,大量编程教程、数据库管理工具navicat教程,欢迎学习!
以上就是golang能使用多核cpu吗的详细内容。