package main
import (
“fmt”
“time”
)
/*
3)使用select可以解决从管道读取数据的阻塞问题[案例演示]
4)goroutine中使用recover,解决协程中出现panic,导致程序崩溃问题,[案例演示]
说明:如果我们起了一个协程,但是这个协程出现了panic,如果我们没有铺货这个panic,就会造成整个程序崩溃,这时我们可以再goroutine中使用recover来捕获panic,进行处理,这样即使这个协程发生的问题,但是主线程仍然不受影响,可以继续执行。
select{
case v:=<管道:
语句
…
default:
语句
}
*/
func main(){
//使用select可以解决从管道取数据的阻塞问题
//1.定义一个管道10个数据int
intChan := make(chan int,10)
for i:=0;i<10;i++{
intChan<-i
}
//2.定义一个管道5个数据string
stringChan := make(chan string,5)
for i:=0;i<5;i++{
stringChan<-"hello"+fmt.Sprintf("%d",i)
}
//传统的方法再遍历管道时,如果不关闭会阻塞而导致deadlock
//问题,再实际开发中,可能我们不好确定什么关闭该管道,
//可以使用select方式可以解决
for{
select {
//:注意这里,如果intChan一直没有关闭,不会一直阻塞而deadlock
//,会自动到下一个case匹配
case v:= <-intChan:
fmt.Printf("从intChan读取的数据%d\n",v)
time.Sleep(time.Second)
case v :=<-stringChan:
fmt.Printf("从stringChan该取得数据%s\n",v)
time.Sleep(time.Second)
default:
fmt.Printf("都取不到了,不玩了,程序员可以加入逻辑\n")
time.Sleep(time.Second)
break
}
}
}