multithreading - runtime.GOMAXPROCS 没有按预期工作

标签 multithreading go taskaffinity

我有一个简单的 go 程序 -

main.go -

package main

import (
    "log"
    "runtime"
    "time"
)

func main() {
    runtime.GOMAXPROCS(1)
    log.Println("running")
    time.Sleep(10 * time.Minute)
}

我像这样构建二进制文件 -

GOOS=linux go build

然后在centos机器上运行-

# ./test
2017/10/27 14:20:15 running

我想知道为什么即使 GOMAXPROCS 设置为 1,这个简单的程序也会使用 2 个不同的内核(1 和 6)。

process using 2 cpu cores

有时也使用 3-4 个核心。

对此有什么想法吗?

谢谢。

最佳答案

您正在运行四个进程。内核将它们调度到核心上。 GOMAXPROCS 与此无关;它只影响单个进程的线程数,并且只影响用户级代码。

关于multithreading - runtime.GOMAXPROCS 没有按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46974078/

相关文章:

c# - 使用 Thread.Sleep() 总是不好的吗?

go - 是否可以使用 dgo 检索当前模式

docker - 已提供标志但未定义

没有显示源代码的godoc

android - 在 Android 11 中无法使用 taskAffinity 进行跨应用程序 Activity

multithreading - 无状态 session 线程安全吗?

.net - 线程的垃圾收集

c - fork 和线程有什么区别?

java - 如何更改Android中的任务关联性?

bash - 命令的交换律