天气预报
该死的While循环解析
现在能告诉我,你发现错误了么?
如果你已经发现错误,那么请跳过本文,本文对你不适用。
对照协议规定的文本看,该程序应该是没有错误啊,怎么回事呢?
协议、协议 -- 协 + 议,说明这个东东是可以讨价还价的,谁能保证所有的程序设计者在所有的细节上面都能保证和协议文本一致,且理解一致呢?且协议这个东西归根还是人制定了,谁能保证最先制定的时候没有缺陷呢?早期的C的规范文本不就有很多未规定项,导致如今编译器支持上面各自发挥的状态,大家应该都有深受其害的经历。
扯远了一点,归根到底是没有人能保证所有程序都能按照协议文本来工作,没人能保证在某种情况下内容被改写(当然应有其他手段,这里不描述)
只要一个简单实例问题就出来了。
usLen = 100
TAG LEN CONT TAG LEN?aucBuffer = {0x01, 0x03, 0x00, 0x02, 0x00, 0x01, 0x02, ... }
很显然错误出在
usOffset += aucBuffer[usOffset + 1];如果aucBuffer[usOffset + 1]=0,伟大的死循环就诞生了。
应该怎么做呢?针对本问题,我的推荐做法如下:
本文为了说明问题,代码都十分之简单,在编写的时候可能还会考虑到,但一旦代码复杂度增加N倍时,这些异常还能保证考虑到么?
该方法解决了死循环的问题。但是万无一失了么?请看下回。
发表于 @ 2007年01月21日 02:08:00|评论(loading...)|编辑