首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

网络协议解析数据设计跟excel辅助生成代码

2013-03-04 
网络协议解析数据设计和excel辅助生成代码在设计一个网络协议解析的模块,实现网络协议解析和设置到底层服

网络协议解析数据设计和excel辅助生成代码
在设计一个网络协议解析的模块,实现网络协议解析和设置到底层服务程序的操作。软件控制流程为:


1、服务程序获取指令字符串。
2、查找对应指令操作函数,跳转执行。
3、指令操作函数查找指令参数,执行操作。
4、组装返回字符串,发送回客户端。


对于数据结构,尽量简洁明了。整个业务的流程很简单,比较繁琐的是指令的数量比较大。为了避免过多的代码编辑(switch case 或者if else if),设计的数据结构如下:


char cGroup[MAX_GROUP_LEN];//1、服务程序获取指令字符串。填充 cGroup//2、查找对应指令操作函数,跳转执行。for(i = 0; i < GroupLAST;++i){if(strcasecmp(cGroup,stGroupParse[i].m_pcMsg) == 0){if(eOperateType == List) iRet = stGroupParse[i].m_ListGroup();else iRet = stGroupParse[i].m_UpdateGroup(); return iRet;}}

设计思路上如此,在其他类似的地方也可以套用。


不过这并不是什么新鲜的东西,很早之前就见到过了。这次做的这个项目,用到了一点以前没有用过的——用excel来辅助生成代码。
excel的CONCATENATE函数(等价于&),作用是拼装字符串。


假设有组名在A3的位置,CONCATENATE("int ",A3,"List(void);")则生成了int IpConfigList(void);
stGroupParse则可以用 "{"&A3&","&""""&A3&""""&","&A3&"List"&","&A3&"Update"&"}"&","公式来生成。一行处理好了之后,用excel往下拉一下就都OK了。



这个用法比较怪异,但是比较适用于这次遇到的字串处理较多,逻辑简单,重复工作量大的情况。我上面贴的代码就是这样生成的。
这次用起来也挺有意思的。

热点排行