// 接收线程 func (self *ltvSession) recvThread(eq cellnet.EventQueue) { var err error var pkt *cellnet.Packet for { // 从Socket读取封包 pkt, err = self.stream.Read() if err != nil { // 断开事件 eq.PostData(NewSessionEvent(Event_SessionClosed, self, nil)) break } // 逻辑封包 eq.PostData(&SessionEvent{ Packet: pkt, Ses: self, }) } if self.needNotifyWrite { // 通知发送线程停止 self.writeChan <- closeWritePacket{} } // 通知接收线程ok self.endSync.Done() }
func (self *mongoDriver) readTask(evq cellnet.EventQueue, usercallback interface{}, execCallback func(*mgo.Database, interface{}) error) { callbackType := reflect.TypeOf(usercallback) callbackValue := reflect.ValueOf(usercallback) resultPtrType := callbackType.In(0) // 取回调函数第一个参数类型 resultType := resultPtrType.Elem() // 实例化 result := reflect.New(resultType) db := self.fetch() err := execCallback(db, result.Interface()) self.back(db) //将回调函数投递到主线程 evq.PostData(func() { errValue := reflect.ValueOf(&err).Elem() // 错误时, 返回空 if err == nil { // http://play.golang.org/p/TZyOLzu2y- callbackValue.Call([]reflect.Value{result, errValue}) } else { // http://grokbase.com/t/gg/golang-nuts/13adpw445j/go-nuts-reflect-set-to-nil callbackValue.Call([]reflect.Value{reflect.Zero(resultPtrType), errValue}) } }) }
func update(db *db.MongoDriver, evq cellnet.EventQueue) { log.Debugln("update") db.Execute(func(ses *mgo.Session) { col := ses.DB("").C("test") col.Update(bson.M{"name": "davy"}, &char{Name: "davy", HP: 1}) evq.PostData(func() { signal.Done(2) }) }) }
func (self *mongoDriver) writeTask(evq cellnet.EventQueue, usercallback func(error), execCallback func(*mgo.Database) error) { db := self.fetch() err := execCallback(db) self.back(db) if usercallback != nil { //将回调函数投递到主线程 evq.PostData(func() { usercallback(err) }) } }
// 接收线程 func (self *ltvSession) recvThread(eq cellnet.EventQueue) { var err error var pkt *cellnet.Packet for { // 从Socket读取封包 pkt, err = self.stream.Read() if err != nil { ev := NewSessionEvent(Event_SessionClosed, self, nil) msgLog("recv", self, ev.Packet) // 断开事件 eq.PostData(ev) break } // 消息日志要多损耗一次解析性能 msgLog("recv", self, pkt) // 逻辑封包 eq.PostData(&SessionEvent{ Packet: pkt, Ses: self, }) } if self.needNotifyWrite { self.Close() } // 通知接收线程ok self.endSync.Done() }