go 命令
线程共享内存, 需要 sync 包进行锁操作
mutex 锁
1 | type Purse struct { |
channel 信道
初始化 ch := make(chan int, bufLen)
发送 ch <- v
接收 v, ok := <-ch
关闭 close(ch)
信道在双方开启前处于阻塞状态, 方便线程之间进行数据同步, 而无需加锁.
信道满后, 写操作阻塞; 信道空后, 读操作阻塞
ok 为 false 表明信道无数据并且已关闭
只有发送者可以关闭信道, 发送者不可以; 信道关闭后再发送数据将触发 panic
一般情况无需关闭信道, 除非接受者必须接收到关闭后触发某些操作.
select
for {
select {
case c <- x:
case <- quit:
return
default:
// 无阻塞, 循环非常快
}
}
定时
interval time.Tick(100 * time.Millisecond)
timeout time.After(500 * time.Millisecond)
sleep time.Sleep(10 * time.Millisecond)
练习
1 | func Walk(t *tree.Tree, ch chan int) { |