您的位置:首页 > 编程语言 > C语言/C++

effective C++: 9.杂项讨论

2013-12-12 20:11 99 查看
九、杂项讨论

条款52:写了placement new也要写placement delete

许多程序员习惯性地忽略编译器警告.他们任务如果是问题真的很严重的话,编译器就应该给一个错误提示信息而

不是警告信息.这种想法看起来似乎很合理,但是在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的编译器的最高(最严厉)警告级别下争取'无任何警告'的荣誉。

不要过度依赖编译器的报警能力,因为不同的编译器对待事情的态度并不相同,一旦移植到另一个编译器上,你原本依赖的警告信息有可能消失.

条款54:让自己熟悉包括TR1在内的标准程序库

请记住:

C++标准程序库的主要机能是由STL,iostreams,locales组成.并包含C99标准程序库.

TR1添加了智能指针(例如tr1::shared_ptr)、一般化函数指针(tr1::function)、hash-based容器、正则表

达式(regular expressions)以及另外10个组件的支持.

TR1自身只是一份规范.为获得TR1提供的好处,你需要一份实物.一个好的实物来源是Boost.

条款55:让自己熟悉Boost

请记住:

Boost是一个社群,也是一个网站.致力于免费、源码开发、同僚复审的C++程序库开发.Boost在C++标准化过程过程中扮演深具影响力的角色.

Boost提供许多TR1组件实现品,以及其他许多程序库.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: