10.1.1 环境变量 GOMAXPROCS
这个 GOMAXPROCS 环境变量(和Go 函数)允许您限制操作系统线程数,它能同时执行用户级 Go 代码。Go 1.5 版本开始,GOMAXPROCS 的默认值应该是您 Unix 机器的内核数。
如果您决定分配给 GOMAXPROCS 的值小于您的 Unix 机器的内核数的话,可能会影响您的程序的性能。然而,使用比可用内核大的 GOMAXPROCS 值也一定不会使您的程序运行的快。
您可用通过编程的方式来发现 GOMAXPROCS 环境变量的值,即相关代码。在下面的 maxprocs.go 程序中找到:
1
package main
2
3
import (
4
"fmt"
5
"runtime"
6
)
7
8
func getGOMAXPROCS() int {
9
return runtime.GOMAXPROCS(0)
10
}
11
12
func main() {
13
fmt.Printf("GOMAXPROCS:%d\n", getGOMAXPROCS())
14
}
Copied!
在一台 Intel i7 处理器的机器上执行 maxprocs.go 产生如下输出:
1
$go run maxprocs.go
2
GOMAXPROCS: 8
Copied!
然而,您可以在程序执行前,通过改变 GOMAXPROCS 环境变量的值来修改上面的输出。在 bash(1) Unix shell 里执行下面的命令:
1
$go version
2
go version go1.9.4 darwin/amd64
3
$export GOMAXPROCS=800; go run maxprocs.go
4
GOMAXPROCS: 800
5
$export GOMAXPROCS=4; go run maxprocs.go
6
GOMAXPROCS: 4
Copied!
Copy link