实现原理:
并发一个函数,等待1s后向timeout写入数据,在select
中如果1s之内有数据向其他channel
写入则会顺利执行,如果没有,这是timeout
写入了数据,则我们知道超时了。
实现代码:
package main
import "fmt"
import "time"
func main() {
ch := make(chan int, 1)
timeout := make(chan bool, 1)
// 并发执行一个函数,等待1s后向timeout写入true
go func() {
time.Sleep(1000)
timeout <- true
}()
// 这里会等待ch或timeout读出数据
// 因为一直没有向ch写入数据
// 在1s后向timeout写入了数据
// 所以执行了timeout的case
// 利用这个技巧可以实现超时操作
select {
case <- ch :
fmt.Println("read from ch")
case <- timeout :
fmt.Println("time out...")
}
}
总结
以上就是这篇文章的全部内容,希望对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。