其他语言

本类阅读TOP10

·基于Solaris 开发环境的整体构思
·使用AutoMake轻松生成Makefile
·BCB数据库图像保存技术
·GNU中的Makefile
·射频芯片nRF401天线设计的分析
·iframe 的自适应高度
·BCB之Socket通信
·软件企业如何实施CMM
·入门系列--OpenGL最简单的入门
·WIN95中日志钩子(JournalRecord Hook)的使用

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
从CString::Mid()的崩掉看问题

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

                                                             从CString::Mid()的崩掉看问题


        今天,当我写的程序拿到另一台电脑上去测试时,发现程序崩掉了。经过一番追踪,我发现我竟然栽在Mid函数手上。我在使用Mid函数时没有判断字符串是否为空,这个函数居然使程序崩掉了。我真的郁闷啊。按照我的习惯的思维,字符串为空时调用Mid函数应该会返回空字符串啊,怎么会崩掉呢?难道CString中的Mid真的有问题吗?这勾起了我去探求Mid函数的兴趣。我通过跟踪进到函数内部,发现其中有几个断言:
        ASSERT(nFirst >= 0);
        ASSERT(nFirst + nCount <= GetData()->nDataLength);
        我是死在了后一个断言手上。所以在Win32 Debug模式下运行程序时,程序自然会崩掉了。呵呵,只要换成Win32 Release模式就一切都OK了。
        问题搞清楚了,该总结以下了:
        1.程序出错了,总要先怀疑自己,确定自己写的没错了,再去找别人的茬去。当我看到当程序运行到Mid()处崩掉时,我一个劲地埋怨写这个函数的人,怎么这么烂,这也会写错,其实是我自己孤陋寡闻,我想这也是一个极不正确的态度,我希望我能改过来。要是你也和我有一样的问题,那么,也下决心改正吧
        2.写程序千万不要偷懒。程序崩掉在很多情况下是因为程序员偷懒造成的(个人见解),如果能多一些合法性检查、空值检查,多一写出错处理,很多程序也就不会那么脆弱了。
       


相关文章

相关软件