首页 > 其他 > 详细

golang学习的点点滴滴:并发超时处理

时间:2014-10-01 12:21:31      阅读:223      评论:0      收藏:0      [点我收藏+]

golang并没有在语言层次上提供超时操作,但可以通过一些小技巧实现超时。

原理:

并发一个函数,等待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...")
	}
}


golang学习的点点滴滴:并发超时处理

原文:http://my.oschina.net/qibin/blog/323725

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!