C++面向对象高级编程(三)

目录

 

1、static

2、class template模版

3、namespace

4、组合

5、继承-public继承

6、虚函数

7、C++中的explicit


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构造函数只能被显式调用。

发布了176 篇原创文章 · 获赞 21 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/qq_27262727/article/details/105013308