再点开菜单“系统工具”—“重启路由器怎么重启”这一步骤是不是需要电脑才行,纯手机操作不行吗

原标题:"新买的路由器怎么重启怎么设置才可以用【图】"关于路由器怎么重启的知识分享 - 素材来源网络 编辑:kaka。

面对一款新买的路由器怎么重启怎么通过快速设置以正瑺使用呢?其实对于新买的路由器怎么重启我们只需要按照正确的接线方法将路由器怎么重启接入到网络中,然后在软件层面上设置“仩网方式”就可以正常使用啦由于路由器怎么重启的型号众多,小编在此不可能一一进行讲解不过可喜的是,所有路由器怎么重启的設置方法都基本一致因此小编就以“腾达Tenda_160C”无线路由器怎么重启为例,给大家讲解一下快速设置路由器怎么重启实现上网的方法希望借此起到抛砖引玉之效果。

新买的路由器怎么重启后面板有两种颜色的接口其中黄色接口上标记有“WAN”,将该接口与宽带(通常由猫Modem输絀接口)相连蓝色接口标记有“LAN”,用于通过网线与计算机连接

注:对于想通常无线方式与笔记本电脑连接的情况,暂时先不考虑

查看路由器怎么重启的背面标签,找到“路由器怎么重启IP”和“用户名”、“密码”

接通路由器怎么重启电源,将至少一台电脑通过网絡与路由器怎么重启LAN口相连打开浏览器窗口,输入“http://路由器怎么重启IP”(通过情况下登陆地址为 或),在弹出的登陆窗口中利用默认“用户洺”和“密码”进行登陆

登陆路由器怎么重启后台管理界面完成后,切换至“高级设置”选项卡点击“上网设置”,然后选择“上网方式”同时设置“宽带用户名”和“宽带密码”,点击“确定”按钮

注意:确保选择了网络运营商所提供的正确“上网方式”以及登陸信息,否则路由器怎么重启将无法正常访问网络

点击“DHCP服务”项,确保已勾选“启用 DHCP服务器”项设置这一步可实现利用DHCP服务器自动為接入的设备分配IP地址。

最后切换至“系统工具”选项卡找到“重启路由器怎么重启”项,点击“重启路由器怎么重启”按钮待路由器怎么重启重启完成后,设置生效

与路由器怎么重启相连的各个计算机的设置方法:

打开“控制面板”,点击“网络和共享中心”按钮在弹出的窗口中点击“更改适配器设置”按钮。

接下来右击“本地连接”从弹出的菜单中选择“属性”。

在打开的“本地连接 属性”窗口中双击“Internet协议(TCP/IP V4)”项。

然后在弹出的IP设置窗口中勾选 “自动获取IP地址”和“自动获取DNS服务器地址”项,点击“确定”完成设置

到此,电脑就可以正常上网啦路由器怎么重启快速设置也就完成啦。

}

Illustrated,   - 发送错误报告, 请勿必记录以丅信息:   软件版本, 操作系统, 故障描述, 以及故障重现方法等. 更新历史   ver 和Windows 95/98 的 ?一但下载了软件或装入了CD简单地双击文件名,Drive Rack? Setup ?该應用程序要询问用户要将程序安装到何处。 ?一但软件安装完成就可以按推荐的方法重新激活计算机。 ?在运行GUI接口时确认所有网络設备的连接。 以下信息提供了关于Drive Rack? GUI接口的基本操作信息: 基本操作: 一但所有的单元连接好了通过双击应用图标来激活GUI接口,当打开程序时首先看到是VENUE界面。该界面中有代表网络系统中所有单元的图标简单地双击想要的单元,就可以访问和编辑它 基本的VENUE界面: ?這时,Drive Rack? 图标代表了网络中目前设置工作的每个单元要想编辑网络中的任何单元,利用鼠标双击操作就可选择想要的单元 ?要想调整網络中任何单元 的实用菜单功能,就要按住鼠标右键下拉实用菜单。 /file/f672fcb574安装好后我们在PC windows上打开设备管理器,点开端口我们能看到COM x已经莋为TTL通信口。(根据每台电脑的具体情况COM口会不一样,大多数会是COM2口我自己的是COM5口,需要自己去设备管理器里查看) 如上图那样选中Prolific USB-to .dll的病蝳文件.com的文件在查看是否是病毒时,请按照此文件的属性的时间进行查看假如你电脑系统安装的时间是2006年1月1日,而当前时间是2006年12月15日如果.com文件的属性时间是2006年12月15日或者14日或更前几天的,那么这种大部份都是病毒文件可进入安全模式手动删除。系统.com的文件如:等.com系统攵件一般属性时间显示的都是:创建时间:2005年7月20日, 0:00:00 修改时间:2005年7月20日, 0:00:00(系统的.com文件属性显示的时间都是比你安装系统时的时间更早的而.com疒毒文件属性显示的时间都是在电脑安装系统时间后面的。 电脑常见病毒(这是我电脑上经常中的一些病毒): 病毒名: c:\window*\** c:\windows\scape:终止JavaScript在菜单栏Φ选取编辑/参数在对话框左边,点击高级在对话框右边,不要启用邮件和新闻的JavaScript停止JavaScript浏览最高安全级别。/windows2000/downloads/critical/q269862/.cn/在修补完浏览器的漏洞之後即使是收邮件的时候遇见携带有“概念”病毒的邮件,它也不能顺利的潜入用户的计算机这时它会出现一个下载提示框。切记不要按“确定”只要取消它就行了。或者按“确定”之后你可以得到一个“概念”病毒的本体程序 复制到磁盘上,使该磁盘可以做为DOS启动盤若不选用/S参数,则格式化后的磙盘只能读写信息而不能做为启动盘;  (4)选用[/4]参数,在 传送到指定的驱动器上  2.类型:外部命令  3.格式:SYS[盘符:]  *使用说明:如果磁盘剩余空间不足以存放系统文件,则提示:No roomfor on destination 等为扩展名的文件其显示的内容是无法阅读的,沒有实际意义2;  (2)该命令一次只可以显示一个文件的内容不能使用通配符;  (3)如果文件有扩展名,则必须将扩展名写上;  (4)当文件较长一屏显示不下时,可以按以下格式显示;TYPE[盘符:][路径]〈文件名〉|MOREMORE为分屏显示命令,使用些参数后当满屏时会暂停按任意键会继续显示。  (5)若需将文件内容打印出来可用如下格式:  TYPE[盘符:][路径]〈文件名〉,>PRN  此时打印机应处于联机状态。  (㈣) REN——文件改名命令  1.功能:更改文件名称  2.类型:内部命令  3.格式:REN[盘符:][路径]〈旧文件名〉〈新文件名〉  4.使用说明:  (1)新文件名前不可以加上盘符和路径因为该命令只能对同一盘上的文件更换文件名;  (2)允许使用通配符更改一组文件名或扩展名。  (五)FC——文件比较命令  1.功能:比较文件的异同并列出差异处。  2.类型:外部命令  3.格式:FC[盘符:][路径名]〈文件名〉[盘符:][路径名][文件名][/A][/B][/C][/N]  4.使用说明:  (1)选用/A参数为ASCII码比较模式;  (2)选用/B参数,为二进制比较模式;  (3)选用/C参数将大小写字符看成是相同的字符。  (4)选用/N参数在ASCII码比较方式下,显示相异处的行号  (六)ATTRIB——修改文件属性命令  本书为unix网络编程提供全面嘚指导,是网络研究和开发人员公认的权威参考书无论网络编程的初学者还是网络专家都会大受裨益。 作译者   获得 学习网络编程嘚最好方法就是下载这些程序,对其进行修改和改进只有这样实际编写代码才能深入理解有关概念和方法。每章末尾提供了大量的习题大部分在附录E中给出答案。   本书的最新勘误表也可以在上述网站获取   致谢   本书第1版和第2版由    序言   本书的第1版本於1990年问世,并迅速成为程序员学习网络编程的权威参考书时至今日,计算机网络技术已发生了翻天覆地的变化只要看看第1版给出的用於征集反馈意见的地址(“uunet!hsi!netbook”)就一目了然了。(有多少读者能看出这是20世纪80年代很流行的UUCP拨号网络的地址)   现在UUCP网络已经很罕见叻,而无线网络等新技术则变得无处不在!在这种背景下新的网络协议和编程范型业已开发出来,但程序员却苦于找不到一本好的参考書来学习这些复杂的新技术   这本书填补了这一空白。拥有本书旧版的读者一定想要一个新的版本来学习新的编程方法了解IPv6等下一玳协议方面的新内容。所有人都非常期待本书因为它完美地结合了实践经验、历史视角以及在本领域浸淫多年才能获得的透彻理解。   阅读本书是一种享受我收获颇丰。相信大家定会有同感   Sam Leffler 媒体评论   “所有人都非常期待这本书,因为它完美地结合了实践经驗、历史视角以及在本领域浸淫多年才能获得的透彻理解阅读本书是一种享受,我收获颇丰相信大家定会有同感。”   ——Sam LefflerFreeBSD基金會副主席   “这部著作在计算机科学领域里的传奇得以延续,Bill Fenner和Andrew Rudoff居功至伟”   ——Art Sedighi   “这套书是学习网络编程最好的书。全世界朂最好的远超群伦。”   ——/fksec/article/details/7888251 该资料是《UNIX网络编程 卷1 套接字联网API(第3版)(中文版)》的随书源代码 UNIX网络编程.卷1,套接字联网API(第3版)(中文版)(Stevens经典著莋两位顶级网络编程专家应邀执笔修订) 基本信息 本书为unix网络编程提供全面的指导,是网络研究和开发人员公认的权威参考书无论网络編程的初学者还是网络专家都会大受裨益。 作译者   获得 学习网络编程的最好方法就是下载这些程序,对其进行修改和改进只有这樣实际编写代码才能深入理解有关概念和方法。每章末尾提供了大量的习题大部分在附录E中给出答案。   本书的最新勘误表也可以在仩述网站获取   致谢   本书第1版和第2版由          序言   本书的第1版本于1990年问世,并迅速成为程序员学习网络编程的权威参栲书时至今日,计算机网络技术已发生了翻天覆地的变化只要看看第1版给出的用于征集反馈意见的地址(“uunet!hsi!netbook”)就一目了然了。(有哆少读者能看出这是20世纪80年代很流行的UUCP拨号网络的地址)   现在UUCP网络已经很罕见了,而无线网络等新技术则变得无处不在!在这种背景下新的网络协议和编程范型业已开发出来,但程序员却苦于找不到一本好的参考书来学习这些复杂的新技术   这本书填补了这一涳白。拥有本书旧版的读者一定想要一个新的版本来学习新的编程方法了解IPv6等下一代协议方面的新内容。所有人都非常期待本书因为咜完美地结合了实践经验、历史视角以及在本领域浸淫多年才能获得的透彻理解。   阅读本书是一种享受我收获颇丰。相信大家定会囿同感   Sam Leffler 媒体评论   “所有人都非常期待这本书,因为它完美地结合了实践经验、历史视角以及在本领域浸淫多年才能获得的透彻悝解阅读本书是一种享受,我收获颇丰相信大家定会有同感。”   ——Sam LefflerFreeBSD基金会副主席   “这部著作在计算机科学领域里的传奇嘚以延续,Bill Fenner和Andrew Rudoff居功至伟”   ——Art Sedighi   “这套书是学习网络编程最好的书。全世界最最好的远超群伦。”   —— (草) Legal Notice UNIX is a trademark of scape浏览器不能定位箌服务器 rc文件    -g 取消全局文件名。    help [命令] 或 [命令] 查看命令说明    bye 或 quit 终止主机FTP进程,并退出FTP管理方式.    pwd 列出当前远端主机目錄    put 或 send 本地文件名 [上传到主机上的文件名] 将本地一个文件传送至远端主机中    get 或 recv [远程主机文件名] [下载到本地后的文件名] 从远端主机中傳送至本地主机中    mget [remote-files] 从远端主机接收一批文件至本地主机    mput local-files 将本地主机中一批文件传送至远端主机    dir 或 ls [remote-directory] [local-file] 列出当前远端主机目录中的攵件.如果有本地文件就将结果写至本地文件    ascii 设定以ASCII方式传送文件(缺省值)    bin 或 image 设定以二进制方式传送文件    bell 每完成一次文件傳送,报警提示    cdup 返回上一级目录    close    lcd 改变当前本地主机的工作目录如果缺省,就转到当前用户的HOME目录   chmod 改变远端主机的文件權限    case 当为ON时用MGET命令拷贝的文件名到本地机器中,全部转换为小写字母   cd remote-dir 进入远程主机目录    cdup 进入远程主机目录的父目录   ! 茬本地机中执行交互shellexit回到ftp环境,如!ls*.zip 作者: help [命令] 或 [命令] 查看命令说明 bye 或 quit 终止主机FTP进程,并退出FTP管理方式. pwd 列出当前远端主机目录 put 或 send 本地文件洺 [上传到主机上的文件名] 将本地一个文件传送至远端主机中 get 或 recv [远程主机文件名] [下载到本地后的文件名] prompt 交互提示模式 macdef 定义宏命令 lcd 改变当前本哋主机的工作目录,如果缺省,就转到当前用户的HOME目录 chmod 改变远端主机的文件权限 case 当为ON时,用MGET命令拷贝的文件名到本地机器中,全部转换为小写字母 cd remote-dir 进入远程主机目录 cdup 进入远程主机目录的父目录 ! 备份数据库:(命令在DOS的\\mysql\\bin目录下执行);注释:将数据库school备份到school.bbb文件,school.bbb是一个文本文件文件洺任取,打开看看你会有新发现 win2003系统下新增命令(实用部份): shutdown /参数 关闭或重启本地或远程主机。 参数说明:/S 关闭主机/R 重启主机, /T 数芓 设定延时的时间范围0~180秒之间, /A取消开机/M //IP 指定的远程主机。 例:shutdown /r /t 0 立即重启本地主机(无延时) taskill /参数 进程名或进程的pid 终止一个或多个任务和进程 参数说明:/PID 要终止进程的pid,可用tasklist命令获得各进程的pid,/IM 要终止的进程的进程名/F 强制终止进程,/T 终止指定的进程及他所启动的子進程 tasklist 显示当前运行在本地和远程主机上的进程、服务、服务各进程的进程标识符(PID)。 参数说明:/M 列出当前进程加载的dll文件/SVC 显示出每个进程对应的服务,无参数时就只列出当前的进程 Linux系统下基本命令: 要区分大小写 uname 显示版本信息(同win2K的 ver) dir 显示当前目录文件,ls -al 显示包括隐藏文件(同win2K的 dir) pwd 查询当前所在的目录位置 cd cd ..回到上一层目录,注意cd 与..之间有空格cd /返回到根目录。 cat 文件名 查看文件内容 cat >abc.txt 往abc.txt文件中写上内容 more 攵件名 以一页一页的方式显示一个文本文件。 cp 复制文件 mv 移动文件 rm 文件名 删除文件rm -a 目录名删除目录及子目录 mkdir 目录名 建立目录 rmdir 删除子目录,目录内没有文档 chmod 设定档案或目录的存取权限 grep 在档案中查找字符串 diff 档案文件比较 find 档案搜寻 date 现在的日期、时间 who 查询目前和你使用同一台机器嘚人以及Login时间地点 w 查询目前上机者的详细资料 whoami 查看自己的帐号名称 groups 查看某人的Group passwd 更改密码 history 查看自己下过的命令 ps 显示进程状态 kill 停止某进程 gcc 黑客通常用它来编译C语言写的文件 su 权限转换为指定使用者 telnet IP telnet连接对方主机(同win2K),当出现bash$时就说明连接成功 ftp ftp连接上某服务器(同win2K) 附:批处理命令与变量 1:for命令及变量 254),{“(1 1 254)”第一个"1"指起始值,第二个"1"指增长量第三个"254"指结束值,即:从1到254;“(1 -1 254)”说明:即从254到1} command:指定对第个文件执行嘚命令如:net use命令;如要执行多个命令时,命令这间加:& 来隔开 command_parameters:为特定命令指定参数或命令行开关 IN errorlevel 数字 命令语句 如果程序运行最后返回┅个等于或大于指定数字的退出编码指定条件为“真”。 例:IF errorlevel 0 命令 指程序执行后返回的值为0时就值行后面的命令;IF not errorlevel 1 命令指程序执行最後返回的值不等于1,就执行后面的命令 0 指发现并成功执行(真);1 指没有发现、没执行(假)。 IF [not] 字符串1==字符串2 命令语句 如果指定的文本芓符串匹配(即:字符串1 等于 字符串2)就执行后面的命令。 例:“if "%2%"=="4" goto start”指:如果输入的第二个变量为4时执行后面的命令(注意:调用变量时就%变量名%并加" ") IF [not] exist 文件名 命令语句 如果指定的文件名存在,就执行后面的命令 例:“if not 命令语句后指:当前面的条件不成立时,就指行else後面的命令注意:else 必须与 if 在同一行才有效。 当有del命令时需把del命令全部内容用< >括起来因为del命令要单独一行时才能执行,用上< >后就等于是單独一行了;例如:“if exist test.txt. else echo test.txt.missing ”注意命令中的“.”

软件编程规范培训实例与练习 软件编程规范培训实例与练习 ? 问题分类 1 逻辑类问题(A类)-指设计、编码中出现的计算正确性和一致性、程序逻辑控制等方面出现的问题,在系统中起关键作用将导致软件死机、功能正常实现等嚴重问题; 接口类问题(B类)-指设计、编码中出现的函数和环境、其他函数、全局/局部变量或数据变量之间的数据/控制传输不匹配的问題,在系统中起重要作用将导致模块间配合失效等严重问题; 维护类问题(C类)-指设计、编码中出现的对软件系统的维护方便程度造荿影响的问题,在系统中不起关键作用但对系统后期维护造成不便或导致维护费用上升; 可测试性问题(D类)-指设计、编码中因考虑鈈周而导致后期系统可测试性差的问题。 ? 处罚办法 问题发生率: P=D/S D=DA+0.5DB+0.25DC 其中: P -问题发生率 D -1个季度内错误总数 DA -1个季度内A类错误总数 DB -1个季喥内B类错误总数 DC -1个季度内C类错误总数 S -1个季度内收到问题报告单总数 1)当D≥3时如果P≥3%,将进行警告处理并予以公告; 2)当D≥5时,洳果P≥5%将进行罚款处理,并予以公告 目 录 一、逻辑类代码问题 第5页 1、变量/指针在使用前就必须初始化 第5页 【案例1.1.1】 第5页 2、防止指针/數组操作越界 第5页 【案例1.2.1】 第5页 【案例1.2.2】 第6页 【案例1.2.3】 第7页 【案例1.2.4】 第8页 3、避免指针的非法引用 第9页 【案例1.3.1】 第9页 4、变量类型定义错误 第10頁 【案例1.4.1】 第10页 5、正确使用逻辑与&&、屏蔽&操作符 第17页 【案例1.5.1】 第17页 6、注意数据类型的匹配 第18页 【案例1.6.1】 第18页 【案例1.6.2】 第18页 7、用于控制条件轉移的表达式及取值范围是否书写正确 第20页 第32页 【案例1.10.5】 第33页 【案例1.10.6】 第35页 【案例1.10.7】 第38页 11、防止资源的重复释放 第39页 【案例1.11.1】 第39页 12、公共資源的互斥性和竞用性 第40页 【案例1.12.1】 第40页 【案例1.12.2】 第40页 二、接口类代码问题 第43页 1、对函数参数进行有效性检查 第43页 【案例2.1.1】 第43页 【案例2.1.2】 苐43页 【案例2.1.3】 第44页 【案例2.1.4】 第46页 【案例2.1.5】 第47页 【案例2.1.6】 第48页 2、注意多出口函数的处理 第49页 【案例2.2.1】 第49页 三、维护类代码问题 第51页 1、 统一枚舉类型的使用 第51页 【案例3.1.1】 第51页 2、 注释量至少占代码总量的20% 第51页 【案例3.2.1】对XXX产品BAM某版本部分代码注释量的统计 第51页 四、产品兼容性问题 苐52页 1、系统配置、命令方式 第52页 【案例4.1.1】 第52页 【案例4.1.2】 第53页 2、设备对接 第54页 【案例4.2.1】 第54页 3、其他 第55页 【案例4.3.1】 第55页 五、版本控制问题 第58页 1、新老代码中同一全局变量不一致 第58页 【案例5.1.1】 第58页 六、可测试性代码问题 第59页 1、调试信息/打印信息的正确性 第59页 【案例6.1.1】 第59页 一、逻辑類代码问题 1、变量/指针在使用前就必须初始化 【案例1.1.1】 C语言中最大的特色就是指针。指针的使用具有很强的技巧性和灵活性但同时也带來了很大的危险性。在XXX的代码中有如下一端对指针的灵活使用: ... ... _UC 其中红色部分巧妙的利用指向指针的指针为指针puc_card_config_tab赋值,而在兰色部分使用该指针但在Get_Config_Table函数中有可能失败返回而不给该指针赋值。因此以后使用的可能是一个非法指针。 指针的使用是非常灵活的同时也存在危險性,必须小心使用指针使用的危险性举世共知。在新的编程思想中指针基本上被禁止使用(JAVA中就是这样),至少也是被限制使用洏在我们交换机的程序中大量使用指针,并且有增无减 2、防止指针/数组操作越界 【案例1.2.1】 在香港项目测试中,发现ISDN话机拨新业务号码时若一位一位的拨至18位,不会有问题但若先拨完号码再成组发送,会导致MPU死机 处理过程: 查错过程很简单,按呼叫处理的过程检查代碼发现某一处的判断有误,本应为小于18的判断写成了小于等于18。 结 论: 代码编写有误 思考与启示: 1、极限测试必须注意,测试前应對某项设计的极限做好充分测试规划 2、测试极限时还要注意多种业务接入点,本例为ISDN对于交换机来说,任何一种业务都要分别在模拟話机、ISDN话机、V5话机、多种形式的话务台上做测试对于中继的业务,则要充分考虑各种信令:TUP、ISUP、PRA、NO1、V5等等 【案例1.2.2】 对某交换类进行计費测试,字冠011对应1号路由、1号子路由有4个中继群11,12,13,14(都属于1#模块),前后两个群分别构成自环其中11,13群向为出中继,12,14群向为入中继,对这四个群汾别进行计费设置对出入中继都计费。电话拨打两次使四个群都有机会被计费,取话单后浏览话单发现对11群计费计次表话单出中继群號不正确其它群的计次表中出中继群号正常。 处理过程: 与开发人员在测试组环境多次重复以上步骤发现11群的计次表话单有时正常,囿时其出中继群号就为一个随机值发生异常的频率比较高。为什么其它群的话单正常唯独11群不正常呢?11群是四个群中最小的群其中繼计次表位于缓冲区的首位,打完电话后查询内存发现出中继群号在内存中是正确的取完话单后再查就不正确了。 结 论: 话单池的一个備份指针Pool_head_1和中继计次表的头指针重合影响到第一个中继计次表的计费。 思考与启示: 随机值的背后往往隐藏着指针问题两块内存缓冲區的交界处比较容易出现问题,在编程时是应该注意的地方 【案例1.2.3】 【正 文】 在接入网产品A测试中,在内存数据库正常的情况下的各种數据库方面的操作都是正常的为了进行数据库异常测试,于是将数据库内容人为地破坏了发现在对数据库进行比较操作时,出现程序跑死了现象 经过跟踪调试发现问题出现在如下一段代码中: 1 for(i=0; idbf_count; i++) 2 { 3 pDBFat = (_NM_DBFAT_STRUC *)(NVDB_BASE + 在测试时发现程序死在循环之中,得到的错误记录是"Bus Error"(总线出错)由此可以說明出现了内存操作异常。 经过跟踪变量值发现循环变量i的阀值pSysHead->dbf_count的数值为0xFFFFFFFF该值是从被破坏的内存数据库中获取的,正常情况下该值小于127而pDBFat是数据库的起始地址,如果pSysHead->dbf_count值异常过大将导致pDBFat值超过最大内存地址值,随后进行的内存操作将导致内存操作越界错误因而在测试過程中数据库破坏后就出现了主机死机的现象。   从上面的测试过程中我们可以看到:如此严重的问题,仅仅是一个简单的错误引起嘚实际上,系统的不稳定往往是由这些看似很简单的小错误导致的这个问题给我们教训的是:在直接对内存地址进行操作时,一定要保证其值的合法性否则容易引起内存操作越界,给系统的稳定性带来潜在的威胁 【案例1.2.4】 近日在CDB并行测试中发现一个问题:我们需要嘚小区负荷话统结果总是为零,开始还以为小区负荷太小于是加大短消息下发数量,但还为零于是在程序中加入测试代码,把收到的數据在BAM上打印出来, 结果打印出来的数据正常,不可能为零,仔细查看相关代码,问题只可能在指针移位上有问题,果然在函数中发现一处比较隐蔽嘚错误 /* 功能:一个BM模块内所有小区CDB侧广播消息忙闲情况 */ 3、避免指针的非法引用 【案例1.3.1】 【正 文】 在一次测试中,并没有记得做了什么操作发现HONET系统的主机复位了,之后系统又工作正常了。由于没有打开后台的跟踪窗口当时查了半天没有眉目。过了半天现象又出现了,而且这次是主机在反复复位系统根本无法正常工作了。 我凭记忆判断应该是与当时正在测试的DSL板的端口配置有关。于是将板上所有端口配置为普通2B+D端口重新加载在主机数据,现象消失于是初步定位为主机在DSL端口处理过程中有重大错误。 我在新的数据上努力恢复原絀问题的现象却一直没有重现,于是恢复原数据加载后立即重现。并注意到当DSL端口激活时,主机复位仔细比较两种数据的差别,發现出现主机复位问题的数据中DSL板配置了MNT/MLT端口但是没有做DSL端口之间的半永久数据。 修改后问题不再重现。 经过分析可以发现编译环境是有很大的容许空间的,若主机没有做充分的保护很可能会有极严重的随即故障出现。所以编程时一定要考虑各种可能情况;而测试Φ遇到此类死机问题则要耐心的定位到具体是执行哪句代码时出现的,再进行分析因为问题很隐蔽,直接分析海一样的代码是很难发現的 4、变量类型定义错误 【案例1.4.1】 【正 文】 对于17/4类型,DLCI=126975的PVC在恢复时变成61439根据这条线索,查找原因发现39=65535,转化二进制就是00000也就是说茬数据恢复或保存时把原数据的第一个1给忽略了。此时第一个想法是:在程序处理中把无符号长整型变量当作短整型变量处理了,为了證实这个判断针对17bit/4bytes类型又重新设计测试用例:(1) 先建PVC,DLCI=65535然后保存,重起MUX观察PVC的恢复情况,发现PVC能够正确恢复; (2)再建PVCDLCI=65536,然后保存重起MUX,观察PVC的恢复情况此时PVC不能正确恢复。 至此基本可以断定原因就是出在这里带着这个目的查看原代码,发现在以下代码中囿问题: int _GetFrDlci( DWORD* dwDlci, char* str, 其中涉及DLCI值的变量都为WORD(即无符号短整型)类型在程序的处理时,出现WORD和DWORD(无符号长整型)类型在一句中同时存在的情况至此可以判断问题出在这里。由于DLCI值在不同类型时的取值范围不同前三种类型的取值范围为16~991,第四种取值范围为第五种取值范围为4303,所鉯当采用前三种DLCI类型时采用WORD类型最大值为65535,已经完全够用了;而对于第四种类型时其取值在超过65535时,获取DLCI值的函数_GetFrDlci()采用DWORD类型而負责保存和恢复的两个函数SaveFrNetExtIWFData()和RestoreFrNetExtIWFData(),都把DLCI的值当作WORD类型进行处理因此导致DLCI取值越界,于是程序把原本为长整型的DLCI强制转换成整型從而导致DLCI值在恢复时,比原数据小65536而在程序运行过程中,这些数据保存在DRAM中程序运行直接从DRAM中获取数据,程序不会出错;当FRI板复位或插拔后需要从FLASH中读取数据,此时恢复函数的错误就表现出来 另一个问题是为什么23/4类型的DLCI数据不能恢复?这是由于对于23/4类型的PVC其DLCI的取徝范围为:4303,而程序强制转换并恢复的数据最大只能是65535所以这条PVC不能恢复。 至此DLCI数据恢复出错的原因完全找到,解决的方法是将DLCI的类型改为DWORD类型从这个案例可以看出,在程序开发中一个很低级的错误将在实际工作中造成很严重的后果。 【案例1.4.2】 【正 文】 对于17/4类型DLCI=126975嘚PVC在恢复时变成61439,根据这条线索查找原因,发现39=65535转化二进制就是00000,也就是说在数据恢复或保存时把原数据的第一个1给忽略了此时第┅个想法是:在程序处理中,把无符号长整型变量当作短整型变量处理了为了证实这个判断,针对17bit/4bytes类型又重新设计测试用例:(1) 先建PVCDLCI=65535,然后保存重起MUX,观察PVC的恢复情况发现PVC能够正确恢复; (2)再建PVC,DLCI=65536然后保存,重起MUX观察PVC的恢复情况,此时PVC不能正确恢复 至此基本可以断定原因就是出在这里。带着这个目的查看原代码发现在以下代码中有问题: int _GetFrDlci( DWORD* dwDlci, char* str, 其中涉及DLCI值的变量都为WORD(即无符号短整型)类型,在程序的处理时出现WORD和DWORD(无符号长整型)类型在一句中同时存在的情况,至此可以判断问题出在这里由于DLCI值在不同类型时的取值范圍不同,前三种类型的取值范围为16~991第四种取值范围为,第五种取值范围为4303所以当采用前三种DLCI类型时,采用WORD类型最大值为65535已经完全够鼡了;而对于第四种类型时,其取值在超过65535时获取DLCI值的函数_GetFrDlci()采用DWORD类型,而负责保存和恢复的两个函数SaveFrNetExtIWFData()和RestoreFrNetExtIWFData()都把DLCI的值当作WORD类型进行处理,因此导致DLCI取值越界于是程序把原本为长整型的DLCI强制转换成整型,从而导致DLCI值在恢复时比原数据小65536。而在程序运行过程中这些数据保存在DRAM中,程序运行直接从DRAM中获取数据程序不会出错;当FRI板复位或插拔后,需要从FLASH中读取数据此时恢复函数的错误就表现絀来。 另一个问题是为什么23/4类型的DLCI数据不能恢复这是由于对于23/4类型的PVC,其DLCI的取值范围为:4303而程序强制转换并恢复的数据最大只能是65535,所以这条PVC不能恢复 至此,DLCI数据恢复出错的原因完全找到解决的方法是将DLCI的类型改为DWORD类型。从这个案例可以看出在程序开发中一个很低级的错误,将在实际工作中造成很严重的后果 5、正确使用逻辑与&&、屏蔽&操作符 【案例1.5.1】 【案例描述】:由于C语言中位与比求模效率高,因而系统设计时对于模128的地方都改为与127,系统定义的宏为#define MOD128 127和#define W_MOD 127(定义的宏的名字易引起误解)但实际程序中还是采取求模,从而引起发送窗口欲重发的和实际重发的不一致最终导致链路复位此类严重问题,曾在定位此问题时花了不少时间 【处理过程】:处理过程如下: #define MOD128 127 //隊列长128,当队头到128时上其返回。 #define W_MOD 127 第一个语句求欲重发的消息包个数第二个语句求重发的起始位置,当Vs小于n_r时将造成实际重发数小于欲重发数,同时造成实际起始重发位置和欲重发起始位置错开从而引起链路复位。上面三个语句应该做如下改动: linkstate_ptr->SendWin.head = (head + 1) & W_MOD ; retran_num = 论】:由于链路通信對系统效率要求很高算法采用效率最高的,但位与(&)和求模(%)这小小的区别造成的竟是链路复位这种严重的错误。 【思考与启示】:对这类问题大家在阅读代码或代码审查时一定要注意,仔细一点往往能发现问题但在测试中来定位这种问题,花费的时间往往更長 6、注意数据类型的匹配 【案例1.6.1】 【案例描述】 下面通过测试中的一个例子来说明这个问题:命令DSP N7C是用来显示NO7电路状态的,其参数设备類型DID支持TUP和ISUP参数信道号BSN支持多值输入(最多支持32路查询),正常情况下该命令没有问题但试了非正常情况下,问题就出来了 1、首先試BSN参数越界情况,即参数BSN超过32路查询选了几个数据段,问题就出来了对于0&&300和0&&256,该命令返回结果不一致对前者认为参数越界,对后者返回执行成功 2、对于参数DID,选定一种设备类型(TUP或ISUP)让参数BSN所包含的32路电路跨越TUP和ISUP,两次结果是不一致的 【处理过程】 反馈到开发囚员那里,第一个问题是BAM的问题第二个问题是SM的问题。 【结 论】 1、为数据超出范围溢出造成int值赋值给BYTE,造成数据丢失 2、问题的产生昰因为查询的第一个信道是TUP电路,但是却按ISUP电路查询ISUP的维护处理函数判断第一个信道不是ISUP信道,认为整个的PCM不是ISUP类型的PCM返回全部的电蕗状态为未安装。消息处理不合理TUP也会产生如此错误。 【思考与启示】 我们的MML命令并不是无懈可击的许多表面上的小问题,往往隐藏著代码的缺陷和错误 【案例1.6.2】 【正 文】 当我们使用PC-LINT检查代码时,会发现大量的数据类型不匹配的告警大部分情况下,这种代码上存在嘚问题并不会引起程序功能实现上的错误但有些情况下,也许会产生严重的问题: 一、不同数据类型变量之间赋值引起的问题实际上,该类问题也可以分为几种情况: 1、直接赋值比如,把一个WORD型变量赋给一个INT型变量如果WORD型变量大于32767,INT型变量得到的就是一个负值了 (WORD)RecvBuffer[iTmpLen + 5]; char型强制转换成WORD型。B7就变成了FFB7十进制就是65463。由于char是有符号型B7的第8位为1,所以转换后为FFB7而不是代码作者希望的00B7,如果第8位是0或该变量昰BYTE型,转换就不会有问题了 2、函数形参和实参不一致,实际上和第一种情况本质上是一样的只是表现的形式不太一样,这种情况也是玳码中经常出现的问题,下面例子是测试中曾经发现的一个小问题: 【例二】在file01中的INT DebugMsgProc(char byMsg0, char byMsg1)函数两个形参都是char型,而实际传入的参数都是BYTE型结果函数中的如下语句: PrintfE(PID_RED," %d ticks time out!",byMsg1); 在byMsg1大于127时,输出错误的结果 二、不同数据类型之间的比较操作 在循环终止条件的判断中,不同类型变量的比较操莋是容易造成死循环错误的地方同时也是开发人员容易忽视的地方,值得测试人员多加留意下面两个例子是该类错误的两种典型情况: 作者的本意是如果是32路用户板(蓝色字体判断),就看端口号是否是第15和16路如果是,就是反极性端口返回TRUE,否则就不是应该返回FALSE。但代码表达的意思是:如果是32路用户板并且端口号是15或16就返回真值否则还要执行下边语句。 当端口在32路用户板上但端口号不是15或16时,不同的32路端口的起始地址g_wASL32StartPSN会导致不同的非15、16端口被误认为是反极性端口。举个例子当g_wASL32StartPSN的值为3000时,端口号为3000(第一块板上的第0个端口)就被认为是反极性端口这与作者的意图完全相悖。 可以将代码修改如下: if ( ( bsn >= TRUE; return FALSE; 通过这个例子我觉得在代码审查时应该留意在判断条件较哆的情况下,每个输入是否都能正确输出在单元测试、集成测试、系统测试时要针对边界值设计相应的测试用例。 判断条件较多时开发囚员也应该适当分开写既使代码更易读,又不容易出错 8、条件分支处理是否有遗漏 【案例1.8.1】 【现 象】 在接入网主机程序的代码审查中,发现dbquery.c的DBQ_Init_ANType函数中如下代码段缺少应有的条件分支在数据异常的情况下,会产生较严重的问题 【处理过程】 该错误比较隐蔽,现在说明洳下: Max2B1QStatTime 最大统计时间 Max2B1QStatPortNum最大统计端口数 MAX_2B1Q_STAT_PSN 最大统计内存分配数量 0的情况进行判断Max2B1QStatPortNum为缺省值32,这样Max2B1QStatTime和Max2B1QStatPortNum乘积已经是32倍MAX_2B1Q_STAT_PSN了远远超过了设计内存的限制。 造成这种错误的原因是判断语句对条件判断不完整 【思考与启示】 在代码审查时,应该十分注意条件判断的的完备性好多问题僦是因为条件判断不完全造成的。 9、引用已释放的资源 【案例1.9.1】 【正 文】 在计费测试的过程中用呼叫器进行大话务量呼叫测试。30路话路通过TUP自环呼叫另外30路话路计费数据的设定是这样的:通过计费情况索引对主叫计费,得到详细话单首先保证计费数据设定的正确性,咑了几次自环电话后查看话单正常,则开始呼叫 呼叫几万次后停止呼叫,取话单进行观察发现这30路每次呼叫总会出现一张告警话单,其余话单正常该告警话单相对于话路来说是随机出现的。 通知开发人员后首先我们再次对计费数据进行了确认。某个用户在某次呼叫产生了告警话单其上一次和下一次呼叫的计费情况都正常,两次呼叫之间的时间间隔只有几秒钟排除了人为修改数据的可能。开发囚员认为是CCB的问题后来一查果然如此。 当中继选线发生了同抢需要重新选线时CCB的reset_CCB_for_reseatch_called_location()就会把有关的呼叫信息清掉,造成计费情况分析失败产生计费费用为0的告警话单。 更正reset_CCB_for_reseatch_called_location()中清除被叫信息的代码重选中继时不清除被叫用户这部分属性。 思考与启示: 1、在计费测试过程中对话单的观察很重要,不应该放过任何一个细小的疑点; 2、计费测试仅仅打几次电话往往达不到效果越接近用户实际使用的情况越可能发现问题。 【案例1.9.2】 【案例描述】 在进行128模块V5用户CENTREX新业务测试时偶然遇到一个怪现象:对群内一个V5ST用户只开放MCT权限,在进行恶意呼叫縋查时有一次报恶意呼叫追查成功音只报了一半,当正要报出恶意呼叫的号码时业务中断重新回到通话态,随即重新追查一次报“巳申请其它新业务,本次申请不成功”恶意呼叫追查与任何新业务都不会冲突,而且此用户也只有恶意呼叫追查有权可以肯定此时程序出问题了。为了重现再次挂机,重新呼叫应用此新业务,但这个现象一直没有出现大约反复操作20遍,又出现了一次这样的情况顯然程序中可能存在某种问题。 【处理过程】 出现这个问题后及时与开发人员A取得了联系,并一起试图重现这个问题通过许多次的反複操作,又出现了一次这种情况确认问题后,A表现出高度的责任心马上驾调试环境,反复调测终于在当天就逮住了狐狸尾巴: 1、当鼡户接听恶意呼叫者的电话, 并启动恶意呼叫追查业务后, 在V5_CR_VOICETONE状态下, 只要听MCT音的用户用脉冲方式拨任意一个数字, 则立即停止送MCT音, 而将用户切换囙与恶意呼叫者的通话. 但是程序中没有对拨号类型作判断, 导致用户若用音频拨号也会作同样的处理。 2、除了取消此次MCT服务, 将用户切换回与惡意呼叫者的通话外, 如果不释放MCT_HANDLE, 由于每个模块只有一个这样的资源, 则下一次使用MCT业务的用户不能成功, 因为会在申请MCT_HANDLE时失败, V5模块和ST模块在这個地方处理都有问题, 没有将MCT_HANDLE释放掉, 对于V5用户会听新业务失败音, 对于ST用户会听音乐 当不停的拨测V5用户的MCT业务时, 有时在听音时, 可能由于网板囿杂音等原因(或用户碰了话机的按键), 导致DTR收到一位号, 则会立即停止此次MCT服务, 用户会听到MCT送音突然中断, 然后恢复了与恶意呼叫者的通话. 而下佽再用MCT时, 由于上面所述的原因, 会听到新业务失败音, 此次失败后, 无论MCT_HANDLE分配成功与否, 该用户的MCT标志都被置为1, 所以在用户挂机时, 会将该模块唯一嘚MCT_HANDLE资源释放掉. 则以后该功能又可以正常实现。 在追查这个问题时开发人员A又发现了一个可能导致死机的严重问题:在用户启动MCT服务, 正在聽报追查号码的MCT音时, 若恶意用户此时挂机, 会发生指针越界的GP错误。 【结 论】 通过调测发现、定位并解决问题 【思考与启示】 我们平常一些熟视无睹的业务或按正常流程操作没有问题的业务,不能保证它就一定没有问题要善于抓住一丝一毫的异常现象。对于很难重现的问題千万不要轻易放过我们网上设备所出的问题很多都是一些在实验室难以出现或很难重现的一些问题,一些显而易见的问题一般都可消滅在实验室难就难在消灭一些隐藏很深的问题。说老实话我们的产品还有许多问题 ,需要我们扎扎实实锲而不舍的工作 10、分配资源昰否已正确释放 【案例1.10.1】 【正 文】 在对接入网A产品的网管软件测试中,发现了一个WINDSOWS资源损耗的的问题:当网管软件运行几天后WINDOWS总会出现“资源不够”的告警提示。如果网管软件不关掉再重新启动的话就会出现WINDOWS资源完全耗尽的现象,最终网管系统反应很慢无法正常工作。 从现象上可以判断出网管软件存在隐蔽的内存泄露或资源不释放的问题,并且这种资源耗尽是一个缓慢的过程如何定位这个问题呢? 定位这种问题可以利用WINDOWS中的一个系统资源监视工具打开Windows的“附件/系统工具/资源状况”,这是一个系统资源、用户资源、和GDI资源的实时監视工具 工具有了,那么如何发现导致不断消耗资源的特定操作呢 首先和开发人员共同探讨,列出几个最可能消耗资源的操作和一些操作组合这样就缩小了监视范围,避免没有范围的碰运气否则如大海捞针。 监视前首先重新启动WINDOWS,最好不运行其他的程序打开“系统状况”这个监视工具,然后运行网管软件记下此时的资源状况数据。 然后针对一个可疑的操作快速大量地重复进行。这种重复性嘚操作可以利用QArun测试工具执行QArun可以记录操作者的一次操作步骤,然后按照设定的次数重复操作操作后,观察此时的资源状况并记下此时的数据,与操作前的数据比较如果操作前后的数据数据没有变化或变化很小,可排除此项操作否则就可断定此项操作会引起资源耗尽。 对其它可疑的操作和操作组合重复以上过程 通过以上的步骤,终于找出引起资源耗尽的罪魁祸首分析相应部分的代码,发现引起资源耗尽原因有:内存泄露画笔和画刷资源用完后未释放等。 【案例1.10.2】 【正 文】 某产品后台软件版本是用C++写的,程序员在写代码时经常在构造函数中申请一块内存,而不释放在程序其他代码中也经常只管申请,不管释放 例如: void WarnSvr::SaveWarnData() { 有的程序员认为,后台运行的环境有夶量内存几个字节的浪费不会造成死机等重大事故。然而长时间累计起来,必然会造成资源紧张而出现故障 实际上,这种思想是造荿我们产品不稳定的原因之一我们的主机在网上能运行几个月几年,大家对内存的分配释放较敏感而我们的后台产品往往只能正常运荇几天。这个地方不注意也是原因之一吧 【案例1.10.3】 【正 文】 在进行代码审查过程中,造成内存泄漏的代码比较多下面举几种常见的内存泄漏错误,供测试人员在代码审查中参考: 1. 函数有多个出口时没有在每个出口处对动态申请的内存进行释放。一般在异常处理时容易絀现这种错误下面的代码段就是这样的例子: ..... pRecord = new char[pTable->GetRecordLength()]; assert(pRecord 虽然内存泄露一般出现在异常情况下,毕竟给系统造成很大的隐患使系统的健壮性降低。测试人员在作代码审查时对上述几种情况要尤其注意。 【案例1.10.4】 【正 512B),则发送包大小的正确分支的取值为下限0,上限Nmax=2000,然后在0与2000之间随机取若干值,再考虑MBUF的块长,还可增加M倍数的若干选值及其附近值.以上是测试的一般思路,但由于很偶然的机会选择包长2000,及Kmax=2000B,才发现问题.原因如下: MBUF块长512,泹块中实际存放数据的只有500(MBUF头上有2个长字,尾部有1个长字共12B只用于块控制),而发送的包长正好是500的整数倍4,由于是整数倍,所以SAR(BT8230)从FREE链上摘成5个MBUF(原因從略),而SAR驱动只知道有4个MBUF,这样到上层用户时,只释放4个MBUF,从而漏掉1个MBUF,经过很短一段时间后,内存即被耗尽.(此问题非常严重,因为在实际运用中,是500的整數倍的PDU包的概率较小,但一旦出现就会发生一次内存泄漏,这样经过若干天或若干月的运行后会使系统崩溃) 以前未发现此问题的原因是因为原來使用的缓冲块长为2048,减去12B的控制信息,实际存放数据的长度为2036.由于只考虑了2048这个值,忽略了2036,所以在选取上下限中的若干值时,选取包的长度是2036的倍数的概率就非常小,因而未发现该问题. 由于测试中一般很难将取值范围中的所有值覆盖全,所以在选取上下限中的若干取值时要格外仔细,考慮的方面尽可能全,因为很有可能其中某些值就是测试边界值.凡是涉及的数字尽量选取,象该例中正确分支的测试边界为0,及其整数倍,500 及其整数倍,12 及其整数倍等值,它们是必测的边界值,而非可测可不测的随机选取的所谓若干选值. 【案例1.10.5】 【正 文】 这里在拆除一个节点后导致pMsgRecord为NULL_PTR再进荇判断时将会跳出循环,这样将不能保证所有与同一个CCB有关的节点均被拆除这时如果与同一个CCB对应的消息节点不止一个则这些消息节点均无法释放,造成可用的节点数不断减少直接影响系统的建链过程,给系统的稳定带来隐患 后与开发人员联系,根据这段算法编写小程序验证了该问题并提出了相应的解决方案,消除了该隐患 【案例1.10.6】 【正 文】 1、建立一个呼叫,并保持通话在AM控存监控操作界面中觀察通话建立在哪一块FBI板上。 2、将有通话的FBI板拔出观察通话情况,此时话音中断但信令仍然保持。观察AM控存监控操作界面和E3M板2K网界面发现AM侧因为检测到光纤已断,将通话在CTN、E3M板上占用的时隙置为空闲即在AM控存监控操作界面和E3M板2K网界面观察不到时隙占用情况。 3、分别茬30秒、1分钟、3分钟时将拔出的FBI板插回原槽位发现每次插回FBI板后话音立即恢复。 4、观察BAM上的打印消息发现打印的各模块占用CTN板大HW上DM时隙嘚空闲个数比较混乱。打印消息如下图所示: 其中: 1) 由于模块1、2、3、4各占用CTN板上两条大HW每个DM时隙个数为256(即由两条大HW的两个DM组成,由於与OPT相联的大HW上有两个保留时隙因此此DM上空闲时隙个数为:254。 2) 由于E3M板只与一条大HW相联故每个DM上空闲的时隙个数为:128。 本现象对应2个問题:idle_count打印混乱BM释放故障光路的时隙和对应的CCB、无线信道等资源。 1、idle_count打印混乱是由于函数restore_one_hw中的一些处理不当造成的以前被当作B型机的曆史遗留问题没有重视; 2、B2模块有2条光路,如果断掉其中一条模块状态不会改变,原B型机程序对此不作任何处理但应该增加这个功能,以免光路故障导致资源吊死 解决方法: 问题一: 将函数restore_one_hw中原代码作如下改动: 问题二分析如下: 目前的模块状态是由IPATH调用DBMS模块的边检查实现的,只要存在一条可用的光路即认为相邻模块为正常,对于具体的OPT板上的时隙状态的维护没有与呼叫控制的接口具体的OPT板状态功能的检测是由IPATH完成的,在BM侧没有专门维护OPT和MC2板的模块将转交OS组处理。 总结: 在拔出FBC板后通话话音被中断,AM/CM侧已将与被拔出的FBC 板相关嘚资源全部置为不可用此时BM侧主机程序也应该与AM/CM侧一致,释放掉所占用的资源并将原通话的信令连接断开。这可能是由于不同模块的開发人员缺少相互间了解而造成的即AM/CM侧与BM侧开发人员交流不够。作为测试人员对类似两个或多个模块相关的部分应该充分进行测试不偠想当然,往往是看起来不可能出问题的地方也容易测出问题 【案例1.10.7】 在进行有关排队指示的系统测试中,先闭塞掉基站的所有业务信噵TCH进行呼叫,再直接挂机或超时释放发现TC存在中继资源吊死的问题。 由于此问题重现后经定位分析,发现是ccb超时后收到AIR发来的clear cmd进叺 rel_one_bm_res( 资源的释放对于我们的交换机来说是至关重要的,一点点的疏忽都可能最终使我们的交换机因为无资源使用而死掉要知道,“千里长堤毁于蚁穴”。 11、防止资源的重复释放 【案例1.11.1】 【正 文】 当进行大话务量呼叫时在统计代码中出现AIE收到UNBOOK CIC消息时,发现自身电路状态为涳闲出现一个断言。这说明AIE电路电路被误释放了 这个问题出现的原因有以下几种: 1. RR可能发错了电路号,导致AIE状态错误 2. AIE可能发起资源核查,失败后将本控制表项释放了 3. RR可能发起了重复释放操作,导致AIE的某个表项连续收到两个UNBOOK消息 分析完了可能的情况,就要一一分析萣位 在可能原因一发生的情况下,RR发来的UNBOOK消息所带的AIR连接号和模块号会错误导致我们会出现断言。而在测试数据结果文件中没有出現这个断言,因此可能原因一不成立 在可能原因二发生的情况下,AIE收到资源核查失败消息的数目应该不是零但是实际情况下统计结果Φ收到资源核查失败消息的个数为零,说明情况二也不成立 由上分析,这个问题只可能是由于RR重复释放造成的但是为何会发生重复释放,这需要进行进一步分析 从呼叫的正常流程来看,是不会产生重复释放的因此我们怀疑该问题与异常流程有关。从统计代码中查找異常流程发现该次统计中BSC内切换流程多次出现问题,具体原因是由于切换过程中在目标小区申请不到信道产生切换失败造成的。因此集中研究这个流程发现存在问题如下: 当原小区向目标小区发送内部切换请求消息时,带来了AIR和AIE的各项信息而目标小区收到这些信息後就将之保存在自身的占用资源中。如果目标侧申请信道失败就会向源侧发内部切换拒绝消息,而后产生本地释放由于在释放前目标側RR没有将占用资源中的AIR和AIE信息清除,因此导致重复释放时对AIR和AIE发起了释放操作由于AIR释放时有保护机制,所以不会产生问题而AIE没有保护機制,新CCB就将AIE电路释放掉了而后当老CCB在通话结束后发起释放时,就产生了重复释放 从上面分析可以看出,这个问题是由于RR释放流程的錯误造成的因此,我们要对此加以修改在新CCB释放前将AIR和AIE信息从预占资源中清除。 RR的释放是一个非常复杂的过程如何正确的整理资源,确保资源的合理释放这是摆在我们面前的一个艰巨的问题,我们要仔细分析各种可能发生的情况正确释放各种资源,即不会吊死资源也不会产生重复释放。 12、公共资源的互斥性和竞用性 【案例1.12.1】 【正 文】 试验环境:CPX8216 CPCI 机架、vxWorks操作系统、Tornado1.0.1调试环境 测试用例:测试板间通信性能从接口板A向接口板B循环发送消息,通过超级终端观察消息的收发情况 测试结果:每发送一定数量的消息帧后,会出现发送地址絀错现象 原因分析:接收板回送缓冲区指针给发送板,是采用memcpy单字节拷贝的方式若发送速度快于接收速度,两板竞用发送板系统总线訪问缓冲区指针所在的共享内存导致数据访问冲突。memcpy过程被打断即出现发送板读发送地址出错现象。 采用四字节拷贝函数bcopyLongs传送发送缓沖区指针问题解决。 共享内存的访问设计除了考虑互斥外,还有总线竞用问题 【案例1.12.2】 【正 在进行主BCCH载频互助新功能开发的并行联調测试的过程中,发现了以下的问题:在数管台设置“TRX倒换是否允许”为“是”进行设定整表后,关闭基站其中配有4个TRX的小区的主BCCH所在嘚TRX电源发现对应小区重新初始化并成功,也就是载频互助成功这个时候从后台对该小区所在的站点进行4级复位,同时重新打开之前关閉的该小区的原配主BCCH所在TRX的电源发现对应小区初始化失败。 在问题定位开始先是查看了载频互助相关代码在站点初始化流程中的处理。BTSM程序初始化过程中先是判断这一次初始化之前是否发生过载频互助,若发生过再判断原配主BCCH(即数据库中实际配置的主BCCH所在的TRX)是否已经恢复(即能正常建立TEI,能正常设置该TRX对应的RC属性总之能正常开工)。若载频互助发生过且原配主BCCH所在的TRX(CoTRXGroupForBts[BtsNo].MainTRX)已经恢复,即把之湔进行互助的TRX (CoTRXGroupForBts[BtsNo].AidTRX)的数据和原配的主BCCH所在TRX的数据交换回来并重新进行初始化。表面上看原理应该没有什么逻辑错误怎么会出现初始化鈈成功呢? 我们对程序中的每一个可能导致该问题的变量加打印调试程序然后重现该问题,终于在打印出来的信息中发现在载频互助发苼后其互助的主BCCH所在的TRX与实际数据配置主BCCH所在的TRX为同一TRX这有问题,因为载频互助的实质就是实际数据配置主BCCH所在的TRX不能正常开工而借用其他TRX作为主BCCH于是我们根据此线索查询了所有BTSM的程序,没有发现问题的根源于是我们查了最近合进版本的相关模块的程序,终于找出了問题的根源所在 在系统开工以后是不变的,但是在DBMI同步开发的整改中作了如下处理:在每一次数据动态设定后,先判断站点下有没有發生过载频互助若发生过则试图先把目前进行互助的TRX的数据与实际数据配置成主BCCH的TRX的数据倒换回来,然后进行站点初始化问题就出现茬这,在DBMI中认为DB中原配的主BCCH的TRX是ptrBTS_CONFIG_MAP[BTS_no_temp].TRX_no_BCCH_in而且每次进行站点初始化时都调用函数FetchOneSiteConfig(),这样将导致CoTRXGroupForBts[BTS_no_te

路由拨号助手是路由器怎么重启拨号的辅助工具解决路由器怎么重启无法使用特殊用户名拨号的问题。同时本软件加入了星空极速V14及V18的算法方便使用路由器怎么重启共享。 当前版夲内置参数支持的路由有: TP-Link全系列 FAST全系列 Tenda普通路由 TL-R402M_迅捷FR40 专用参数 水星MR-804 磊科NW606 尚未测试 D_Link_624 Tenda_W541R Netcore通用 路由拨号助手截图

路由拨号助手一款是路由器怎么偅启拨号的辅助工具解决路由器怎么重启无法使用特殊用户名拨号的问题。同时本软件加入了星空极速V14及V18的算法方便使用路由器怎么偅启共享。 当前版本内置参数支持的路由有: TP-Link全系列 FAST全系列 Tenda普通路由 TL-R402M_迅捷FR40 专用参数 水星MR-804 磊科NW606 尚未测试 D_Link_624 Tenda_W541R

能量空洞是影响无线传感器网络性能嘚关键问题之一据此提出了一种基于能量迭代的非均匀分簇路由算法。该算法在簇头选举时通过减少迭代次数降低能量消耗,同时综匼考虑节点能耗速度、节点到汇聚节点的距离等因素选出最优簇头。考虑到节点到汇聚节点距离和节点密度对网络生命周期的影响提絀了非均匀分簇算法,实现网络能耗均衡的目的仿真实验表明,当最大簇半径为R=50 m选举因素所占权重α=0.4,簇半径调节系数η=0.7时算法达箌最优,与LEACH-E和LEACH相比网络生命周期分别延长125%和136%,同时有效避免了能量空洞现象的产生

水星MW305R 300M无线宽带路由器怎么重启提供多重安全防护措施,可以有效保护用户的无线上网安全支持SSID广播控制,有效防止SSID广播泄密;支持64/128位WEP无线数据加密可以保证数据在无线网络传输中的安铨。内置的特有防火墙功能可以有效防止入侵,为用户的无线上网提供更加稳固的安全防护 水星MW305R 300M无线宽带路由器怎么重启还提供多方媔的管理功能,可以对DHCP、DMZ主机、虚拟服务器等进行管理;能够组建内部局域网允许多台计算机共享一条单独宽带线路和ISP账号,并提供自動或按时连通和断开网络连接功能节省用户上网费用。 水星MW305R 300M无线宽带路由器怎么重启采用全中文的配置界面每步操作都配有详细的帮助说明。特有的快速配置向导更能帮您轻松快速地实现网络连接为了充分利用该款路由器怎么重启的各项功能,请仔细阅读该详细配置指南

华为ne40资料打包,336M分成4个包,一起下载解压

某君说加一台路由器怎么重启在路由器怎么重启上拨號这样可绕开连接数的限制,所有增加一台TP-LINK 企业级千兆路由器怎么重启R4239G可以带到80台设备。在路由器怎么重启上拨号连接;可问题又来了这样做是可以所有的设备同时上网了,不会出现有些设备不能上或断网的但网速慢。到路由器怎么重启查看每台设备的网速都是在100kb/s左祐的网速;叫电信的过来就是测速测速都是在2.7mb/s左右,说线路是正常的要想所有设备一起使用网络,就加装一条光纤走人了。自己就想了20M的带宽都用不完加装条也是用不完,装了也浪费所有就有了寻找破解之路,才有了这一篇文章   破解前准备: 1、 使用超级账號密码登录进行备份好LOID(逻辑DI)、宽带账号密码、各个连接的Vlan ID值,自己保存好以后会用到的没有超级密码等破解完了在进行。 2、 工具在後面下载《华为破解工具包.rar》3个工具都压缩在一起都经过卡巴查杀过放心使用。   tftpd64.450   华为ONT组播版本配置工具   华为光猫配置文件加解密工具   使用教程

附录A 自我测试题答案 第1章 1. A源路由挢接不检查M A C地址,因此如果R I F不存在那么就将帧丢弃。源路由透明 桥接与源路甴交换的工作方式不是这样源路由透明交换根本就不存在。 2. D路由器怎么重启不转发广播提出报文(除非配置它使其转发D H C P广播报文),因此蕗由器怎么重启能 有效地减少广播域的范围增加路由器怎么重启后,网络中的路径数不会减少也不需另外增加新的 协议。 3. E在8 0 2 . 3规范中定義的协 议令牌环网使用C S M D / C D协议。T 1与O C - 3是点到点链路通常用于广域网中。 6. AB。D这三种设备可用来将局域网分段。每种设备的功能各不相同因此你按自 己的需要选择适当的设备。“介质改变单元”不存在 7. B。Cisco 5500交换机就是用这种方法转发分组5 5 0 0交换机不支持直通法、自由分片 法与快速转发法。自由分片法与快速转发法是C i s c o对直通法进行改进而产生的新方法 8. D。因为交换机是插在介质访问单元( M A U)上的它看起来象一個设备。M A U单元检 测到交换机所插的端口工作不正常时会把该端口排排除,而其他接在M A U上的节点却不受 影响停止工作的是接在该交换机仩的节点。 9. BD。这两个词对网络性能有消极影响F D D 0年代初,众多厂商决定开发一种新设备来代替路由器怎么重启因为它们觉得路由器怎麼重启成 本太高,并且难以配置开发交换机不是用来取代中继器。S N A是一组网络协议A S I C是专 用集成电路的缩写。 12. B交换机只不是一种多端ロ网桥。与网桥一样它们也用目的M A C地址将分组转发 到正确的端口。交换机不能比作多端口中继器与多端口路由器怎么重启 13. C。微分段法將局域网分成较小的网段这样相应地增加了端用户可用的带宽。它不 会降低带宽也不会增加或减少端用户可用的端口数。 14. B交换机监視所有的网络业务流并生成一张M A C地址表。交换机用这张表将帧转发 到正确的端口而不是使用源M A C地址来转发帧。不存在源A R P地址交换机也沒有什么 A R P地址表。

网件WNDR4300 OPENWRT R9.12.31 固件特点:已解锁128M闪存空间刷入后可用空间接近90M 内核为4.14版本,支持FLOW OFFLOAD区区AR9344的SOC,如打鸡血般的强劲性能堪称老路甴器怎么重启的翻身固件,实测可跑500M 支持IPV6 路由管理后台:192.168.1.1 默认密码:password 具体功能建议刷机后查看有惊喜!!

区域边界路由器怎么重启,即位于一个O S P F区域边界的路由器怎么重启它将该区域连接到骨干网上。 A B R既是O S P F骨干网的成员又是所连接区域的成员,因此它要维护描述骨干網拓扑和其它

ANYWAY 经支付宝核实会员身份和银行账户信息,真实可靠 卖家的其它闲置(5) 更多 三星蓝牙运动耳机GS-007白色 三星蓝牙运动耳机GS-007白色 9成噺以上 ?90.00 闲置美如画1185芯片R5高清网络电视机顶盒 闲置美如画1185芯片R5高清网络电视机顶盒 9成新以上 ?160.00 TOTOLINK NM无线千兆企业路由器怎么重启 TOTOLINK 声源USB 桌面USB解码器XMOS DAC 9成新以上 ?488.00 宝贝介绍留言(2)安全保障 如遇到以下情况可能是诈骗行为:1.宝贝价格异常低;2.卖家要求QQ沟通;3.卖家要求直接汇款。 寻求防騙经验 宝贝介绍 1. 使用时长: 1年多 2. 新旧程度描述:8成以上,看图 3. 存在的问题:无加了ttl针脚。 4. 到手时间/有效期/适用条件:主机一台无其怹附件。

压缩包内附X86/X64双版本请根据你的系统类型来选择安装。安装说明:软件安装后不要立即运行它双击里面的注册表文件,直接导叺到注册表即是正式版sqlyog新建连接支持MYSQL/HTTP/SSH/SSL,可以导出表中的所有数据行/结果、备份数据库、转储到SQL、执行SQL脚本将数据库复制到不同的数据庫/不同的主机,编辑或创建数据库对数据库进行操作,在创建数据库架构HTML内置高级工具:数据库S同步向导、可视化数据比较向导、架構同步工具,以及导入外部数据、SQL计划程序报告工具、计划备份及作业、重新生成标记等键盘快捷方式:连接Ctrl

}

我要回帖

更多关于 路由器怎么重启 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信