Go语言-runtime.GOMAXPROCS(调整并发的运行性能)

Go语言-runtime.GOMAXPROCS

什么是runtime.GOMAXPROCS

NumCPU

runtime 调度器是个非常有用的东西,关于 runtime 包几个方法:

  • Gosched:让当前线程让出 cpu 以让其它线程运行,它不会挂起当前线程,因此当前线程未来会继续执行
  • NumCPU:返回当前系统的 CPU 核数量
  • GOMAXPROCS:设置最大的可同时使用的 CPU 核数
  • Goexit:退出当前 goroutine(但是defer语句会照常执行)
  • NumGoroutine:返回正在执行和排队的任务总数
  • GOOS:目标操作系统
package main

import (
	"fmt"
	"runtime"
)

func main() {
	fmt.Println("cpus:", runtime.NumCPU())
	fmt.Println("goroot:", runtime.GOROOT())
	fmt.Println("archive:", runtime.GOOS)
}

GOMAXPROCS

runtime.GOMAXPROCS该函数的作用是设置当前进程使用的最大cpu数,返回值为上一次调用成功的设置值。

/**
GOMAXPROCE
调用runtime.GOMAXPROCS()用来设置可以并行计算cpu核数的最大值
并返回之前的值。默认值所有机器核数
*/
package main

import (
	"fmt"
	"runtime"
)

func  main(){
	//设置cpu最大核数
	n:=runtime.GOMAXPROCS(1)
	fmt.Println("之前核数=",n)
	for{
		//两个协程抢着输出 0,1;观察01交替密度来观察;核数越大,交替越密
		go fmt.Print(0)
		fmt.Print(1)
	}
}

GOMAXPROCS 同时也是一个环境变量,在应用程序启动前设置环境变量也可以起到相同的作用。

Go 1.5 版本之前,默认使用的是单核心执行。从 Go 1.5 版本开始,默认执行上面语句以便让代码并发执行,最大效率地利用 CPU。

从 Go 1.5 版本开始,即默认使用所有cpu的,非特殊情况不需要改。Go默认执行使用的CPU核心数为系统CPU最大核心

参考

Golang中runtime的使用详解
https://www.jb51.net/article/168802.htm
Go语言GOMAXPROCS(调整并发的运行性能)
参考URL: http://c.biancheng.net/view/94.html

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
`runtime.GOMAXPROCS` 是 Go 语言中的一个函数,用来设置可同时执行的最大 CPU 数量。在默认情况下,Go 程序会使用机器上所有的 CPU 核心。但在一些情况下,我们可以通过调用 `runtime.GOMAXPROCS` 来限制可同时执行的最大 CPU 数量,以达到一些优化的目的。 例如,在有些情况下,我们可能需要限制可同时执行的最大 CPU 数量,以避免过度使用系统资源。在这种情况下,我们可以将 `runtime.GOMAXPROCS` 设置为一个较小的值,例如 1,以限制程序的并发执行。 另外,在一些情况下,我们可能需要增加可同时执行的最大 CPU 数量,以加快程序的执行速度。在这种情况下,我们可以将 `runtime.GOMAXPROCS` 设置为系统上的 CPU 核心数量,以实现最大并发执行。 下面是一个示例,展示了如何使用 `runtime.GOMAXPROCS` 函数来设置可同时执行的最大 CPU 数量: ```go package main import ( "fmt" "runtime" ) func main() { // 获取系统上的 CPU 核心数量 numCPU := runtime.NumCPU() // 设置可同时执行的最大 CPU 数量 runtime.GOMAXPROCS(numCPU) fmt.Printf("set GOMAXPROCS to %d\n", numCPU) } ``` 在上面的代码中,我们首先调用 `runtime.NumCPU()` 函数来获取系统上的 CPU 核心数量,然后将其传递给 `runtime.GOMAXPROCS` 函数来设置可同时执行的最大 CPU 数量。最后,我们打印出设置的结果。 需要注意的是,虽然可以通过 `runtime.GOMAXPROCS` 函数来设置可同时执行的最大 CPU 数量,但在大多数情况下,我们不需要手动设置该值,因为 Go 程序默认会使用机器上所有的 CPU 核心,以实现最大并发执行。只有在特定的情况下,才需要手动设置该值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

西京刀客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值