第四章 北邮 大三下 现代交换原理 实验二 摘挂机检测实验.docxVIP

第四章 北邮 大三下 现代交换原理 实验二 摘挂机检测实验.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验报告课程名称:现代交换原理与通信网技术实验名称:摘挂机检测实验班级号:姓名:schnee指导教师:实验目的摘挂机检测实验用来考查学生对摘挂机检测原理的掌握情况。实验原理及设计设用户在挂机状态时扫描输出为“0”,用户在摘机状态时扫描输出为“1”,摘挂机扫描程序的执行周期为200ms,那么摘机识别,就是在200ms的周期性扫描中找到从“0”到“1”的变化点,挂机识别就是在200ms的周期性扫描中找到从“1”到“0”的变化点,该原理的示意图如下所示:在我们的实验中,我们把前200ms的线路状态保存以备这次可以读取,同时读出这次的线路状态,把前200ms的线路状态取反与这次的线路状态相与,如果为1,就说明检测到摘机消息了。同理,我们把这次的线路状态取反再与前200ms的线路状态相与,如果为1就说明检测到挂机消息了,然后把摘挂机信号作为事件放入摘挂机队列中。实验主要数据结构函数功能为:检测到摘、挂机事件,并把该事件放入到摘挂机事件队列中。函数原型:void scanfor200(int linestate200[LINEMAX],int linestate[LINEMAX],UpOnnode * head1, UpOnnode* end1);其中LINEMAX为线路总数,是定义在bconstant.h中的一个宏,linestate200[LINEMAX]为已保存的200ms前线路状态,linestate[LINEMAX]为当前的线路状态,head1,end1为摘挂机队列的首尾指针,该队列已经在主程序中进行了初始化。我们所要做的就是把检测到的摘挂机事件以摘挂机队列节点的形式插入到摘挂机事件队列中。数据结构说明:头文件:bconstant.h;(以下的数据结构都已在该文件中定义)LINEMAX :最大线路数;int linestate200[LINEMAX],linestate[LINEMAX]:线路从0开始编号;状态:1:有电流,0无电流;enum UporOn {ehandup,ehandon} :为摘挂机区别符:ehandup表示摘机,ehandon表示挂机;struct UpOnnode //摘挂机队列节点结构{UporOn phonestate; //摘挂机区别符;int linenum; //线路号(从0开始);struct UpOnnode* next; //指向下一节点的指针;};注意事项:我们编写的模块是基础实验部分预加载的本局交换系统的一个模块而已,在系统中head1头指针和end1尾指针已经完成初始化。为方便起见,我们的摘挂机事件队列是一个包含头节点的单向链表,并且头指针指向该头节点,尾指针在初始化时也指向了该节点。所以在我们的函数编写中应保证头指针始终指向该头节点上、尾指针指向摘挂机事件队列的最末一个节点。注意把这次扫描的线路状态值保存在前200ms扫描线路状态数组中,以便主程周期调用。实验效果检验程序执行后能正确检测摘挂机动作并且能进行通话,与预计结果相符,试验成功。实验步骤预习实验内容,了解实验要求;熟悉实验平台和测试环境;编写C程序实现所要求的功能;测试程序;完成实验报告。实验主体流程图实验代码#include bconstant.hextern C _declspec(dllexport) void scanfor200(int linestate200[LINEMAX], int linestate[LINEMAX],UpOnnode * head1,UpOnnode * end1){int up,down;for(int i =0;i=LINEMAX;i++){struct UpOnnode* now = new struct UpOnnode;up =(!linestate200[i])linestate[i];down=(!linestate[i] )linestate200[i];if(up || down){if(up) now-phonestate=ehandup;else now-phonestate=ehandon;now-linenum = i;now-next = 0;end1-next=now;end1=now;}}return;}//此函数不需修改extern C _declspec(dllexport) void freenode(UpOnnode * node) {delete node;}实验结果程序执行后能正确检测摘挂机动作并且能进行通话,与预计结果相符,试验成功。实验心得这次实验依旧比较简单,编程实现也还比较顺利。此外,由于较好的代码能力,我的代码编写也比其他同学简洁不少。只是其间由

文档评论(0)

xiaofei2001129 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档