现在的位置: 首页 > 综合 > 正文

条款53:不要轻忽编译器的警告

2013年10月21日 ⁄ 综合 ⁄ 共 817字 ⁄ 字号 评论关闭

条款53:不要轻忽编译器的警告
    Pay attention to compiler warnings.

    许多程序员习惯性地忽略编译器警告.他们任务如果是问题真的很严重的话,编译器就应该给一个错误提示信息而
不是警告信息.这种想法看起来似乎很合理,但是在C++语言上,我觉得编译器作者对代码即将会爆发的事情应该比你有
更加深入的理解,你说呢?下面我举的这个例子是多多少少在大部人身上都发生过一个错误:
    struct B{
        virtual void f()const;
    };
    struct D:public B{
        virtual void f();
    };
    我现在的编译器给出了这样的警告信息:warning:D::f()hides virtual B::f()
    大部分经验不足的程序员对这个信息的反映都是一副不以为然的态度,他们认为,D::f遮掩了B::f显然是发生了名
字遮掩现象,给出这样的信息很正常啊!错,此刻的编译器是在试图告诉你声明于B中的f并未在D中被重新声明,而是被整
个遮掩了(Item 33描述为什么会遮掩).如果忽略这个警告,几乎肯定导致错误的程序行为,然后是许多的调试行为,只
为了找出编译器早就试图告诉你的事情.
    你应该知道,编译器给出的信息往往和它们'看起来'的意义十分不同!不管怎么样,在你打发某个警告信息之前,请
确定你了解它试图说出的精确意义.It is very important.
    你也应该知道,警告信息天生和编译器相依,不同的编译器有不同的警告标准.所以草率编程后依赖编译器为你指出
错误,是非常不明智的选择.
    请记住:
    ■ 严肃对待编译器发出的警告信息.努力在你i的编译器的最高(最严厉)警告级别下争取'无任何警告'的荣誉。       
    ■ 不要过度依赖编译器的报警能力,因为不同的编译器对待事情的态度并不相同,一旦移植到另一个编译器上,你原
本依赖的警告信息有可能消失.

抱歉!评论已关闭.