zl程序教程

您现在的位置是:首页 >  其它

当前栏目

GOMAXPROCS的使用

使用
2023-06-13 09:16:17 时间
  1. GOMAXPROCS的作用是控制你的程序最大能跑满几个逻辑CPU,也就是通常我们说的几核几核
  2. 默认情况下GOMAXPROCS的值就是NumCPU()的值
  3. 程序中设置了GOMAXPROCS的值后,此后的所有程序都会被限制在这个值内,所以,要想单独控制某段程序的负载,请设置完后,再设置回来。如下测试案例,SleepWait控制最多使用一半的cpu,我的虚拟机是6核,所以cpu轻松跑到300%,10秒过后,如果我不把Test_GOMAXPROCS注释的那段放开,主程序也会最大负载300%
  4. 当程序已经有协程阻塞时,runtime.GOMAXPROCS(runtime.NumCPU())会被阻塞,直到所有协程都无阻塞。
func Test_GOMAXPROCS(t *testing.T) {
    SleepWait(10 * time.Second)
    fmt.Println("???")
    // result := runtime.GOMAXPROCS(runtime.NumCPU())
    // fmt.Println("result", result)
    for i := 0; i < 8; i++ {
        go func() {
            for {
            }
        }()
    }
    select {}
}

func SleepWait(duration time.Duration) {
    fmt.Println("?")
    result := runtime.GOMAXPROCS(runtime.NumCPU() / 2)
    fmt.Println("result", result)
    done := make(chan bool)
    for i := 0; i < 8; i++ {
        go func() {
            defer fmt.Println("!!")
            for {
                select {
                case <-done:
                    return
                default:
                }
            }
        }()
    }
    fmt.Println("duration:", duration)
    <-time.After(duration)
    close(done)
    fmt.Println("??")
}