登录
首页 >  Golang >  Go问答

goroutine必须在不同的CPU上运行吗?

来源:stackoverflow

时间:2024-03-12 19:39:26 253浏览 收藏

Golang不知道大家是否熟悉?今天我将给大家介绍《goroutine必须在不同的CPU上运行吗?》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

问题内容

以下摘录自 https://go.dev/doc/ effective_go#parallel。

我们在循环中独立启动各个部分,每个 cpu 一个。它们可以按任何顺序完成,但这并不重要;我们只是在启动所有 goroutine 后清空通道来计算完成信号。

const numCPU = 4 // number of CPU cores

func (v Vector) DoAll(u Vector) {
    c := make(chan int, numCPU)  // Buffering optional but sensible.
    for i := 0; i < numCPU; i++ {
        go v.DoSome(i*len(v)/numCPU, (i+1)*len(v)/numCPU, u, c)
    }
    // Drain the channel.
    for i := 0; i < numCPU; i++ {
        <-c    // wait for one task to complete
    }
    // All done.
}

本文为何指定“每个 cpu 一个”?多个 goroutine 不需要在不同的 cpu 上执行。事实上,本小节的最后一段提醒读者并发性不是并行性:

请务必不要混淆并发性(将程序构建为独立执行的组件)和并行性(在多个 cpu 上并行执行计算以提高效率)的概念。


正确答案


不,但有可能。

这里没什么可看的。

可以说 5 或 2。实际上,这里没有隐藏任何重要的东西。这只是一个例子,不是goroutine调度的规范。

理论要掌握,实操不能落!以上关于《goroutine必须在不同的CPU上运行吗?》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>