golang 中内存模型
https://segmentfault.com/a/1190000008230146
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | package main import ( "time" "log" ) var a string func hello() { time.Sleep(time.Millisecond * 900) // 这里如果sleep 1 秒的话, 执行程序时可能看不到打印的 “hello” log.Println(a) } func main() { a = "hello\n" go hello() time.Sleep(time.Second) } |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | package main import ( // "log" "time" ) var a string var c = make( chan int) func main() { go func () { a = "hello\n" print( "recv begin..\n" ) time.Sleep(time.Second*3) <-c sum :=0 //后面这四行注释,打印顺序变为:sb, rb, re,se. 不注释时打印顺序可能为:sb,rb,re,se. (sb: send begin, se: send end..) for i := 0; i<1<<24; i++ { sum += i } print( "recv end..\n" ) }() print( "send begin..\n" ) c <-12 print( "send end..\n" ) print(a) time.Sleep(time.Second*2) } |
注释4行:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步