【发布时间】:2025-12-12 13:00:02
【问题描述】:
为什么time.Sleep(time.Nanosecond)被注释掉后下面的程序会挂起?
package main
import "fmt"
import "time"
import "sync/atomic"
func main() {
var ops uint64 = 0
for i := 0; i < 50; i++ {
go func() {
for {
atomic.AddUint64(&ops, 1)
time.Sleep(time.Nanosecond)
}
}()
}
time.Sleep(time.Millisecond)
opsFinal := atomic.LoadUint64(&ops)
fmt.Println("ops:", opsFinal)
}
第二个问题,为什么running this program in the sandbox 会导致“进程耗时太长”?
【问题讨论】:
标签: go