More Effective C++
1,在任何情况下都不能使用指向空值的引用,一个引用必须总是指向某些对象。而指针可以指向空值,而引用不能。因为不存在指向空值的引用,因此引用前不需要检查合法性,所以引用效率高。
2,指针可以被重新赋值以指向另一个不同的对象,但引用总是指向在初始化时被指定的对象,以后不能改变。
3,重载某个操作时应该使用引用。
4,当知道指向一个对象并且不想改变其指向时,或者在重载操作并为防止不必要的语义误解时,你不应该使用指针,除此之外的其他情况下,则应使用指针。
5,const_cast:用于类型转化掉表达式的const或volatileness属性。去除const属性。
dynamic_cast:用于安全的沿着类的继承关系向下进行类型转换:其把指向基类的指针或引用转化成指向其派生类或其兄弟类的指针或引用。(指针转换失败返回空指针,引用转化失败抛出异常),
但其不能用于缺乏虚函数的类型上也不能用它来转换掉constness;
6,reintepret_casts:最普通的用途就是在函数指针类型之间转换。
7,类继承的最重要的特性是可以通过基类指针或引用操作派生类,这样的指针或引用具有行为的多态性,但不能对数组使用多态。
8,避免无用的缺省构造函数(没有参数的构造函数):
9,c++编译器能够在两种数据类型之间进行隐士转换。有两种函数允许编译器进行隐士类型转换:单参数构造函数,隐士类型转换运算符。
10,构造函数用explicit声明,编译器会拒绝了隐士类型转换而调用构造函数.c++编译器会把》作为一个符号来解释,在两个>间没有空格,语句会产生语法错误。除非确实需要,不要定义类型转换函数。
11,++前缀和后缀:前缀返回一个引用,后缀返回的一个const类型;当指针为空时strlen不会被调用很重要。
12,new和operator new的区别:前者是先构造函数初始化后分配 内存,后者是只分配内存返回一个指向内存的指针。delete和operator delete同理。
13,使用析构函数和构造函数防止资源泄漏。禁止异常信息传递到析构函数外:在析构函数调用释放函数外加上try catch
14,虚拟构造函数能返回一个指针,指向调用该函数的对象的新拷贝,只是调用它们真正的拷贝构造函数。
15,让构造函数成为public,析构函数为private可防止直接delete,可以用一个成员函数调用delete,
16,用模板类实现二维数组的传参问题
17,为了维护那些必须同时供C++和C使用的头文件工作,当用C++编译时,应该加extern “C”{}看做是申明在这个函数应该被当做好像c写的一样而进行调用,但用C编译时,不应该这样。
通过只在C++编译器定义的宏_cplusplus 可以将头文件组织成: #ifdefine _cplusplus extern “C”{ #endif 。。。 #ifdefine _cplusplus } #endif
More Effective C++
最新推荐文章于 2020-05-24 00:37:06 发布