#define ASPECT_RATIO 1.653 名为ASPECT_RATIO的值在预编译阶段被替换成1.653,如果在这个常量上出现编译错误,我们可能会困惑1.653的值是什么意思,于是将因为跟踪它而浪费时间. 我们需要使用一个常量来替换上述的宏 const double AspectRatio = 1.653; 当我们以常量替换#define 时,有两种特殊情况需要考虑 第一:常量指针的定义放在头文件内,需要被不同的源代码访问,因此有必要将指针声明为const,如: const char…
对于内置类型以外的初始化责任落在构造函数身上.如下: class PhoneNumber{}; class ABEntry{ public: ABEntry( const string& name, const string& address, const list<PhoneNumber>& phones ); private: string theName; string theAddress; list<PhoneNumber> thePhones;…
永远在使用对象之前先将它初始化.对于无任何成员的内置类型,你必须手工完成此事. 至于内置类型以外的任何其他东西,初始化责任落在构造函数身上.规则很简单:确保每一个构造函数都将对象的每一个成员初始化. 构造函数成员初始化列表: 这里有一个规则:总是在初始化列表中列出所有成员变量,即使有的成员变量是内置类型(内置类型的初始化和赋值成本相同). 成员初始化顺序 base classes 早于 derived classes 被初始化,class 的成员变量总是以其声明次序被初始化 一个编译单元内定义的…
为内置型对象进行手工初始化,因为C++不保证初始化它们. 构造函数最好使用成员初值列,而不要在构造函数本体内使用赋值操作.初值列列出的成员变量,其排列次序应该和它们在class中的声明次序相同. 为免除“跨编译单元之初始化次序”问题,请以local static对象替换non-local static对象.…
读取未初始化的值会导致不明确的行为.在某些平台上,仅仅只是读取未初始化的值,就可能让你的程序终止运行.更可能的情况是读入一些“半随机”bits,污染了正在进行读取动作的那个对象,最终导致不可预知的程序行为,以及许多令人不愉快的调试过程. 对于内置类型的对象手动初始化 对于内置类型以外的任何其他东西,初始化责任落在构造函数身上. 但要区别赋值和初始化.对象的成员变量的初始化动作发生在进入构造函数本体之前. 在上述代码中,theName,theAddress和thephones都不是被初始化,而是被…
Item4 确保对象被使用前进行初始化 C++在对象的初始化上是变化无常的,例如看下面的例子: Int x; 在一些上下文中,x保证会被初始化成0,在其他一些情况下却不能够保证.看下面的例子: Class Point { Int x,y; }; Point p; P的数据成员有时候保证能够被初始化(成0),有时候却不能.如果你从不存在未初始化对象的语言中转到c++, 就需要注意了,因为这很重要. 使用未初始化对象的坏处 读取未初始化的值会产生未定义的行为.在一些平台中,仅仅读取未初始化的值就会让…
成员初始化 在c和c++ 中,使用为初始化的类型经常会引发不可预料的错误,从而使得我们要花费巨大的时间用于调试查找问题,所以确定对象被使用前已被初始化是个非常好的习惯. 永远在使用之前对对象进行初始化.对于无不论什么成员的内置类型,你必须手工完毕初始化操作.由于c++不保证初始化他们. 内置类型意外的其它东西,初始化责任落在构造函数身上.但要注意区分构造函数中的变量是赋值还是初始化. 举个样例 class PhoneNumber{...}; class ABEntry{ public: ABEn…
危害:读取未初始化的值会导致不明确甚至是半随机化的行为. 最佳处理办法:永远在使用对象之前先将它初始化:确保每一个构造函数都将对象的每一个成员初始化. 1 注意区分赋值和初始化: 从初始化的角度而言,这不是一个最佳的处理办法.虽然这会让对象的指最终为你期望的值,但是实际上,对象的成员变量的初始化动作发生在进入构造函数本体之前.而在构造函数本体之内,不是被初始化,而是被赋值. 2 较佳的写法:使用成员变量初始化列表 结果和上一个的最终结果相同,但是效率较高. 规定:总是在初值列表中列出所有成员变量…
阅读effective c++ 04 (30页) 提到的static对象和堆与栈对象."不同编译单元内定义的non-local static对象". 了解一下.    目录 stack与heap 1.Stack 2.Heap 或謂 system heap 3.例子 1.构造函数型 (stack) 2.new型 (heap 動態分配) 4.构造函数型 (stack) 1.stack objects 的生命期 2.static local objects 的生命期 3.global obj…
阅读effective c++ 04 (30页) 提到的static对象和堆与栈对象.看了看侯老师的内存管理视频1~3.有点深. 了解一下. 目录 1 内存管理 1.1 C++内存管理详解 1.1.1 内存分配方式 1.1.2 控制C++的内存分配 1.1.3 常见的内存错误及其对策 1.1.4 指针与数组的对比 1.1.5 指针参数是如何传递内存的? 1.1.6 杜绝"野指针" 1.1.7 有了malloc/free为什么还要new/delete? 1.1.8 内存耗尽怎么办? 1.…