C++之不带指针类的设计——Boolean
经典的类设计分类
- 带指针类
- 不带指针类
Header文件的布局
#ifndef __COMPLEX__
#define __COMPLEX__
#include <iostream.h>
class complex //前置申明
class complex
{
...//类声明
}
complex::function()...//类定义
#endif
类声明
class complex //class head
{ //class body
public:
complex (double r = 0, double i = 0): re (r), im (i) { }
complex& operator += (const complex&);
double real () const { return re; } //函数在body内定义,则自动成为inline候选人
double imag () const { return im; }
private:
double re, im;
friend complex& __doapl (complex *, const complex&);
};
构造函数
构造函数是类中非常重要的函数,在类创建的时候由系统自动调用
complex (double r = 0, double i = 0)//默认参数,在不传参的时候直接使用默认值
: re (r), im (i) //初始值列表,在创建成员的时候直接赋值,比在创建之后赋值效率高
{ }
- 构造函数可重载:重载的时候注意是否有默认参数
- 构造函数可以是private :private的时候不允许外部创建对象,这个是在singleton的时候经常用到。
常量成员函数
double real () const { return re; }
在函数名后面加const修饰符,一般情况下加const表示这个函数不会修改内部的成员变量。能加的尽量加上const。
const complex a(1,2);//由于a是const的,而类的设计者在设计real()的时候没有const,调用会报错
a.real();
参数传递和返回值传递
- 传值
- 传引用
值传递会发生拷贝,当传递比较大的数据时,拷贝是一件很费时间和效率的事情,所以在传值和引用之间首选传引用,但是需要考虑有些时候是不能传引用的,比如临时对象
friend(友元)
自由取得friend的private成员 相同class的各个object互为友元
操作符重载
操作符重载可以看做是特殊的函数,可以是成员函数,也可以是非成员函数,如果是成员函数的话,默认第一个参数是this指针,一般不写。
![](http://images2015.cnblogs.com/blog/19200/201702/19200-20170209222425166-1415087702.png)这种情况下就不能写成是成员函数了,因为和其它类型的对象相加
![](http://images2015.cnblogs.com/blog/19200/201702/19200-20170209222435807-1040259625.png)这种情况下,返回的是临时对象,临时对象返回值绝对是不能用引用的
重点回顾:
- 数据Data一定放在“class body”的pirvate中
- 参数parameters尽可能使用 pass by reference 方式传递
- 返回值return value 尽量用 pass by reference 来传递
- class的body主体内不做变更的参数 或 返回值 应该 const 标识符,表示不希望被修改
- 构造函数中有一个 initialization list,要尽量去使用。与在构造函数体内部进行参数初始化赋初值效率更高
返回值在什么情况下,不能使用pass by reference?
如果函数的返回值是在函数体内部临时创建用来存放结果值(是local的),那么在函数结束时这个临时对象的生命周期就结束了【虽然仍然可以吧reference传递出来但是是错误的】。这种情况则不能使用pass by reference。