MiniOB 1
MiniOB is one mini database, helping developers to learn how database works.
载入中...
搜索中...
未找到
Public 成员函数 | Protected 属性 | 所有成员列表
Communicator类 参考abstract

负责与客户端通讯 更多...

#include <communicator.h>

类 Communicator 继承关系图:
MysqlCommunicator PlainCommunicator CliCommunicator

Public 成员函数

virtual RC init (int fd, Session *session, const std::string &addr)
 接收到一个新的连接时,进行初始化 更多...
 
virtual RC read_event (SessionEvent *&event)=0
 监听到有新的数据到达,调用此函数进行接收消息 如果需要创建新的任务来处理,那么就创建一个SessionEvent 对象并通过event参数返回。 更多...
 
virtual RC write_result (SessionEvent *event, bool &need_disconnect)=0
 在任务处理完成后,通过此接口将结果返回给客户端 更多...
 
Sessionsession () const
 关联的会话信息
 
struct event & read_event ()
 libevent使用的数据,参考server.cpp
 
const char * addr () const
 对端地址 如果是unix socket,可能没有意义
 

Protected 属性

Sessionsession_ = nullptr
 
struct event read_event_
 
std::string addr_
 
BufferedWriterwriter_ = nullptr
 
int fd_ = -1
 

详细描述

负责与客户端通讯

在listener接收到一个新的连接(参考 server.cpp::accept), 就创建一个Communicator对象。 并调用init进行初始化。 在server中监听到某个连接有新的消息,就通过Communicator::read_event接收消息。

成员函数说明

◆ init()

RC Communicator::init ( int  fd,
Session session,
const std::string &  addr 
)
virtual

接收到一个新的连接时,进行初始化

CliCommunicator , 以及 MysqlCommunicator 重载.

◆ read_event()

virtual RC Communicator::read_event ( SessionEvent *&  event)
pure virtual

监听到有新的数据到达,调用此函数进行接收消息 如果需要创建新的任务来处理,那么就创建一个SessionEvent 对象并通过event参数返回。

CliCommunicator, MysqlCommunicator , 以及 PlainCommunicator 内被实现.

◆ write_result()

virtual RC Communicator::write_result ( SessionEvent event,
bool &  need_disconnect 
)
pure virtual

在任务处理完成后,通过此接口将结果返回给客户端

参数
event任务数据,包括处理的结果
need_disconnect是否需要断开连接
返回
处理结果。即使返回不是SUCCESS,也不能直接断开连接,需要通过need_disconnect来判断 是否需要断开连接

CliCommunicator, MysqlCommunicator , 以及 PlainCommunicator 内被实现.


该类的文档由以下文件生成: