好好爱自己!

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行:

 

posted @   立志做一个好的程序员  阅读(135)  评论(0编辑  收藏  举报
努力加载评论中...

不断学习创作,与自己快乐相处

点击右上角即可分享
微信分享提示