关键字
- chan
修饰符:<-chan只读,chan<-只写,chan读写,默认是阻塞的,非阻塞需要用select
带缓冲定义:ch := make(chan int, 10),缓冲满了就阻塞
- select
监听io并触发case操作
- 每个case语句里必须是一个IO操作
- 所有channel表达式都会被求值、所有被发送的表达式都会被求值
- 如果任意某个case可以进行,它就执行(其他被忽略)。
- 如果有多个case都可以运行,Select会随机公平地选出一个执行(其他不会执行)。
- 如果有default子句,case不满足条件时执行该语句。
- 如果没有default字句,select将阻塞,直到某个case可以运行;Go不会重新对channel或值进行求值。
- defer
defer语句实际上是压栈操作,在return后出栈。所以语句后进先出执行
- panic和recover
程序执行的停止和恢复
缺陷
记一次latency问题排查:谈Go的公平调度的缺陷