doutong6814 2019-07-24 06:04
浏览 554
已采纳

为什么从代码调用Setenv不起作用?

I have a simple test project which is expected to print goroutine scheduling messages while it is running.

Setting the env from Goland configuration it works. but it doesn't from code like below, the app doesn't print scheduling infomation. Anybody explains what happens ehre?

func TestScheduler1() {

    var wg sync.WaitGroup
    wg.Add(10)

    for i := 0; i < 10; i++ {
        go work(&wg)
    }

    wg.Wait()
    // Wait to see the global run queue deplete.
    time.Sleep(3 * time.Second)
}

func work(wg *sync.WaitGroup) {
    time.Sleep(time.Second)

    var counter int
    for i := 0; i < 1e10; i++ {
        counter++
    }

    wg.Done()
}

init function is like:

 func init()  {
    os.Setenv("GOMAXPROCS", "1")
    os.Setenv("GODEBUG", os.Getenv("GODEBUG") + "schedtrace=1000,scheddetail=1")
}
  • 写回答

1条回答 默认 最新

  • 普通网友 2019-07-24 07:50
    关注

    go command documentation mentions that go examines some environment variables:

    The go command, and the tools it invokes, examine a few different environment variables.

    So, env variables are checked before the program starts, i.e in build time. When you set these variables from code, the program already runs.

    It works from the IDE since the variables are applied before the compilation, therefore the code runs with all the changes you need.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 Android STD快速启动
  • ¥15 如何使用simulink建立一个永磁同步直线电机模型?
  • ¥30 天体光谱图的的绘制并得到星表
  • ¥15 PointNet++的onnx模型只能使用一次
  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动