go routine 是轻量级的线程
参考:https://studygolang.com/articles/4071
go fun_name()
go func() {fmt.Println("test")}()
chan 在 routine间传递数据
https://my.oschina.net/u/2518341/blog/530182
ch:=make(chan int,1)
ch<-1
fmt.Println(<-ch)
注意,buffered channel 和 unbuffered channel 的区别,unbuffer channel 发送时也会阻塞
https://studygolang.com/articles/8021
//下面这样会报死锁
ch:=make(chan int) //make 没有指定长度
ch<-1
fmt.Println(<-ch)
select
https://blog.youkuaiyun.com/john_f_lau/article/details/55254324
注意select有default 则会不断轮询,如果没有default会阻塞?
func tick_test(){
tick := time.Tick(10000 * time.Millisecond)
abort:=make(chan struct{})
go func() {
os.Stdin.Read(make([]byte,1))
abort<- struct {}{}
}()
select {
case t:=<-tick:
fmt.Println("tick.",t)
case <-abort:
fmt.Println("abort")
return
default:
fmt.Println("...")
}
}
context
https://www.cnblogs.com/zhangboyu/p/7456606.html
https://studygolang.com/articles/10155?fr=sidebar
本文深入探讨了Golang中的goroutine概念及其作为轻量级线程的特点,并通过实例介绍了如何使用channel在goroutine间传递数据。此外,还讨论了buffered与unbuffered channel的区别及select语句的应用。
1632

被折叠的 条评论
为什么被折叠?



