目录
1、static
static是存在特定区域
2、class template模版
3、namespace
4、组合
5、继承-public继承
重要:构造有内而外,析构由内而外。
继承最有价值时跟虚函数搭配。
6、虚函数
在任何成员函数之前加上virtual就是虚函数,虚函数有以下三种:虚函数(重新定义)、纯虚函数(必须定义)、非虚函数
父类写不出来,延缓一段时间让子类来完成。上图所示,搭建应用框架,把固定写好的写好,写不出来的固定成虚函数,给子类来写。在main函数里面,通过子类对象调用父类函数OnFileOpen,执行到Serialize之后发现子类定义了,然后执行子类虚函数。具体例子如下:
继承+复合下的构造和析构
7、C++中的explicit
C++中, 一个参数的构造函数(或者除了第一个参数外其余参数都有默认值的多参构造函数), 承担了两个角色。 1 是个构造器 ,2 是个默认且隐含的类型转换操作符。
所以, 有时候在我们写下如 AAA = XXX, 这样的代码, 且恰好XXX的类型正好是AAA单参数构造器的参数类型, 这时候编译器就自动调用这个构造器, 创建一个AAA的对象。
这样看起来好象很酷, 很方便。 但在某些情况下(见下面权威的例子), 却违背了我们(程序员)的本意。 这时候就要在这个构造器前面加上explicit修饰, 指定这个构造器只能被明确的调用/使用, 不能作为类型转换操作符被隐含的使用。
explicit构造函数是用来防止隐式转换的。请看下面的代码:
class Test1
{
public:
Test1(int n)
{
num=n;
}//普通构造函数
private:
int num;
};
class Test2
{
public:
explicit Test2(int n)
{
num=n;
}//explicit(显式)构造函数
private:
int num;
};
int main()
{
Test1 t1=12;//隐式调用其构造函数,成功
Test2 t2=12;//编译错误,不能隐式调用其构造函数
Test2 t2(12);//显式调用成功
return 0;
}
Test1的构造函数带一个int型的参数,代码23行会隐式转换成调用Test1的这个构造函数。而Test2的构造函数被声明为explicit(显式),这表示不能通过隐式转换来调用这个构造函数,因此代码24行会出现编译错误。
普通构造函数能够被隐式调用。而explicit构造函数只能被显式调用。