golang 超时demo

场景:

判断一个“事务”是否超时。

package main

import "time"

func main()  {

	newChan:=make(chan int,1)
	newDelayTimer:=time.NewTimer(time.Duration(time.Second*2))
	println("start timer:",time.Now().Format("2006-01-02 15:04:05"))
	//newChan<-111
	time.Sleep(time.Second*3)
	go sendMes(newChan)

	select {
	case <-newDelayTimer.C:
		println("delay!",time.Now().Format("2006-01-02 15:04:05"))
	case newMsg:=<-newChan:
		println("newMsg chan :",time.Now().Format("2006-01-02 15:04:05"))
		println(newMsg)
	}
}

func sendMes(newChan chan int){
	println("start insert chan :",time.Now().Format("2006-01-02 15:04:05"))
	newChan<-222
}

sendMes不适合用在io流中,比如如果想从数据流中读数据然后用超时定时器判断是否超时。不使用time.sleep,go sendMes()会读不到数据,sendMes只执行一次,且很大可能它执行时数据流中还没有数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值