golang中channel的超时处理

xjshi · · 7170 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

并发中超时处理是必不可少的,golang没有提供直接的超时处理机制,但可以利用select机制来解决超时问题。

func timeoutFunc() {
	//首先,实现并执行一个匿名的超时等待函数
	timeout := make(chan bool, 1)
	go func() {
		time.Sleep(1e9)	//等待1秒钟
		timeout <- true
	}()

	//然后,我们把timeout这个channel利用起来
	select {
		case <- ch:
			//从ch中读到数据
		case <- timeout:
			//一直没有从ch中读取到数据,但从timeout中读取到数据
	}
}

 


有疑问加站长微信联系(非本文作者)

本文来自:博客园

感谢作者:xjshi

查看原文:golang中channel的超时处理

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

7170 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传