goruntine
go fun()
默认有几核就跑满几核 GoMaxPROCS(n) 设置,n int 几核
channel定义、注意
var bianliang chan type
单向通道 <- chan,chan + 左右键
close( chan )后 ,chan 未取完的值 任然可以 取值
Select 关键词 ,Select{} 代表阻塞
for { <- chan } 循环取chan内的值,去掉 for 只能取一次
结束后要关闭 chan ,不关闭chan,易死锁
Channel 锁
sync.Mutex 互斥锁,处理数据竞态临界值问题,读写频率相近时使用
sync.RWMutex 读写互斥锁,读多写少场景
sync.Once 只执行一次,如赋值,初始化。sync.Once.do(fun) fun不能带参数,使用闭包
sync.Map{}
原子操作
场景:异步、并发等
异步日志文件存储