[手游项目3]-14-go 的 time ticker NewTimer、NewTicker time.After

https://www.cnblogs.com/zihunqingxin/p/4755168.html

https://blog.csdn.net/busai2/article/details/82503699

https://www.jb51.net/article/146063.htm

func (self *Observe) start() {
	if self == nil || self.roomid <= 0 {
		return
	}
	antnet.Go2(func(cstop chan struct{}) {
		obMgr.Store(self.roomid, self)
		defer obMgr.Delete(self.roomid)
		if !self.sendStart() {
			return
		}

		ticker := time.NewTicker(time.Second * 1)
		timeout := time.After(time.Hour * 1)
		sendbuf := bytes.NewBuffer(make([]byte, 1024*16))
		defer func() {
			ticker.Stop()
			self.Over()
			self.sendFrame(sendbuf)
			self.sendOver()
		}()

		for {
			select {
			case <-cstop:
				return
			case <-self.over:
				return
			case <-ticker.C:
				if !self.sendFrame(sendbuf) {
					return
				}
			case <-timeout:
				antnet.LogWarn("ob room:%d is too long", self.roomid)
				return
			}
		}
	})
}

 

posted @ 2019-03-25 17:42  byfei  阅读(68)  评论(0编辑  收藏  举报