channel 虽然很好用,但是我们也要考虑异常情况,比如:超时
go 语言怎么解决这个超时问题呢?
可以利用 select 语句:
select 的用法与 switch 语言非常类似,由 select 开始一个新的选择块,每个选择条件由 case 语句来描述。
与 switch 语句可以选择任何可使用相等比较的条件相比,select 有比较多的限制,其中最大的一条限制就是每个 case 语句里必须是一个 IO 操作。
看这样一个程序:
它会一直随机输出0和1
介绍完 select 语句,然后我们看 go 语言的 channel 超时机制的实现,代码:
24行模拟了真实的超时时间,6秒,超时后给 timeout 信道推送了 true,for 循环里读到了超时信号后中断程序,故,输出如下:
不要通过共享内存来通信,而应该通过通信来共享内存