本文主要是介绍Zinx框架-游戏服务器开发001:zinx框架的安装,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 1 zinx下载地址
- 1.1 zinx框架的源码路径:
- 1.2 安装好之后动态库的位置
- 2 Zinx框架运行的基本概况
- 3 测试Zinx-框架的基本使用
- 3.0 流程预览
- 3.1 初始化框架
- 3.2 标准输入回显标准输出的编写思路
- 3.2.1 回显Echo
- 3.2.2 写标准输入stdin通道类,用通道输入-通过 Ichannel 继承
- 3.2.3 标准输出通道输出-通过 Ichannel 继承
- 3.3 将通道对象添加到框架
- 3.4 添加命令处理类
- 3.4.1 GetNextHandler
- 3.4.2 CmdHandler
- 3.4.3 ExitFramework
- 3.4.4 AddDate
- 3.6 总览
1 zinx下载地址
1.1 zinx框架的源码路径:
https://github.com/marklion/zinx.git
1.2 安装好之后动态库的位置
cp libzinx.so /usr/lib/
cp *.h /usr/include/
2 Zinx框架运行的基本概况
3 测试Zinx-框架的基本使用
3.0 流程预览
+----------------+ +------------------+
| console input +-------------> |TestStdin::ReadFd |
+----------------+ +--------+---------+|||v+---------+----------+|Echo::InternelHandle|+---------+----------+||||v
+---------------+ +---------+----------+
| console output+<--------------+TestSTDOut::WriteFd |
+---------------+ +--------------------+
3.1 初始化框架
/*1-初始化框架*/ZinxKernel::ZinxKernelInit();
3.2 标准输入回显标准输出的编写思路
- 创建三个类:标准输入类,回显类,标准输出类
- 重写标准输入类的读取函数
- 重写回显类处理函数
- 重写标准输出类的写出函数
- 创建以上三个类的全局对象(堆对象),添加通道对象到框架 (kernel)
- 运行框架
3.2.1 回显Echo
从哪里输入的不用管,只需要关心参数。
IZinxMsg& _oInput
来自于上一个环节。
/*2-写功能处理类*/
class Echo :public AZinxHandler {virtual IZinxMsg* InternelHandle(IZinxMsg& _oInput) override{/*回显到标准输出*/GET_REF2DATA(BytesMsg, input, _oInput);//写一个标准输出类的通道,交给通道进行输出Ichannel* poSendOut = ZinxKernel::Zinx_GetChannel_ByInfo("stdout");if (NULL != poSendOut){ZinxKernel::Zinx_SendOut(input.szData, *poSendOut);}return nullptr;}virtual AZinxHandler* GetNextHandler(IZinxMsg& _oNextMsg) override{return nullptr;}
} *poEcho = new Echo();
3.2.2 写标准输入stdin通道类,用通道输入-通过 Ichannel 继承
/*3-写通道类*/
class TestStdin :public Ichannel {// 通过 Ichannel 继承virtual bool Init() override{return true;}virtual bool ReadFd(std::string& _input) override{cin >> _input;return true;}virtual bool WriteFd(std::string& _output) override{return false;}virtual void Fini() override{}virtual int GetFd() override{return 0;}virtual std::string GetChannelInfo() override{return "stdin";}virtual AZinxHandler* GetInputNextStage(BytesMsg& _oInput) override{return poCmd;}
};
注意这里,GetChannelInfo()只负责获取stdin,然后下一步交给回显poCmd做。这里需要一个poCmd,因此在3.2定义类的时候直接创建new了一个对象 *poEcho = new Echo();
,作为全局对象。
virtual AZinxHandler* GetInputNextStage(BytesMsg& _oInput) override
{return poCmd;
}
3.2.3 标准输出通道输出-通过 Ichannel 继承
/*创建标准输出通道类*/
class TestStdout :public Ichannel {// 通过 Ichannel 继承virtual bool Init() override{return true;}virtual bool ReadFd(std::string& _input) override{return false;}virtual bool WriteFd(std::string& _output) override{cout << _output << endl;return true;}virtual void Fini() override{}virtual int GetFd() override{return 1;}virtual std::string GetChannelInfo() override{return "stdout";}virtual AZinxHandler* GetInputNextStage(BytesMsg& _oInput) override{return nullptr;}
} *poOut = new TestStdout();
3.3 将通道对象添加到框架
TestStdin* poStdin = new TestStdin();
ZinxKernel::Zinx_Add_Channel(*poStdin);
ZinxKernel::Zinx_Add_Channel(*poOut);
3.4 添加命令处理类
- 创建命令处理类继承AzinxHandler,重写处理函数和获取下一个处 理环节的函数
- 处理函数内,根据输入内容不同,要么添加输出通道,要么摘除输 出通道
- 获取下一个处理环节函数中,指定下一个环节是退出或回显
设定输入通道的下一个环节是该类对象
3.4.1 GetNextHandler
virtual AZinxHandler* GetNextHandler(IZinxMsg& _oNextMsg) override{GET_REF2DATA(BytesMsg, oBytes, _oNextMsg);if (oBytes.szData == "exit"){return poExit;}else{if (0 == status){return poEcho;}else{return poAddDate;}}}
} *poCmd = new CmdHandler();
3.4.2 CmdHandler
class CmdHandler :public AZinxHandler {int status = 0;// 通过 AZinxHandler 继承virtual IZinxMsg* InternelHandle(IZinxMsg& _oInput) override{/*判断输入是否是open或close,执行不同操作*/GET_REF2DATA(BytesMsg, oBytes, _oInput);if (oBytes.szData == "open"){ZinxKernel::Zinx_Add_Channel(*poOut);return NULL;}else if (oBytes.szData == "close"){ZinxKernel::Zinx_Del_Channel(*poOut);return nullptr;}else if (oBytes.szData == "date"){status = 1;return nullptr;}else if (oBytes.szData == "cleardate"){status = 0;}return new BytesMsg(oBytes);}
3.4.3 ExitFramework
class ExitFramework :public AZinxHandler {// 通过 AZinxHandler 继承virtual IZinxMsg* InternelHandle(IZinxMsg& _oInput) override{GET_REF2DATA(BytesMsg, obyte, _oInput);if (obyte.szData == "exit"){ZinxKernel::Zinx_Exit();return NULL;}/*创建交给下一个环节处理的数据*/return new BytesMsg(obyte);}virtual AZinxHandler* GetNextHandler(IZinxMsg& _oNextMsg) override{return poEcho;}
} *poExit = new ExitFramework();
3.4.4 AddDate
class AddDate :public AZinxHandler {// 通过 AZinxHandler 继承virtual IZinxMsg* InternelHandle(IZinxMsg& _oInput) override{GET_REF2DATA(BytesMsg, oBytes, _oInput);time_t tmp;time(&tmp);string szNew = string(ctime(&tmp)) + oBytes.szData;BytesMsg* pret = new BytesMsg(oBytes);pret->szData = szNew;return pret;}virtual AZinxHandler* GetNextHandler(IZinxMsg& _oNextMsg) override{return poEcho;}
} *poAddDate = new AddDate();
3.6 总览
这篇关于Zinx框架-游戏服务器开发001:zinx框架的安装的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!