[/h2]override
当在父类中使用了虚函数时候,你可能需要在某个子类中对这个虚函数进行重写,以下方法都可以:
class A{ virtual void foo();}class B : public A{ void foo(); //OK virtual void foo(); // OK void foo() override; //OK}如果不使用override,当你手一抖,将foo()写成了f00()会怎么样呢?结果是编译器并不会报错,因为它并不知道你的目的是重写虚函数,而是把它当成了新的函数。如果这个虚函数很重要的话,那就会对整个程序不利。所以,override的作用就出来了,它指定了子类的这个虚函数是重写的父类的,如果你名字不小心打错了的话,编译器是不会编译通过的:
class A{ virtual void foo();};class B : public A{ virtual void f00(); //OK,这个函数是B新增的,不是继承的 virtual void f0o() override; //Error, 加了override之后,这个函数一定是继承自A的,A找不到就报错};final
当不希望某个类被继承,或不希望某个虚函数被重写,可以在类名和虚函数后添加final关键字,添加final关键字后被继承或重写,编译器会报错。例子如下:
class Base{ virtual void foo();};class A : public Base{ void foo() final; // foo 被override并且是最后一个override,在其子类中不可以重写};class B final : A // 指明B是不可以被继承的{ void foo() override; // Error: 在A中已经被final了};class C : B // Error: B is final{};
string str1("I am a string");//语句1 直接初始化string str2(str1);//语句2 直接初始化,str1是已经存在的对象,直接调用构造函数对str2进行初始化string str3 = "I am a string";//语句3 拷贝初始化,先为字符串”I am a string“创建临时对象,再把临时对象作为参数,使用拷贝构造函数构造str3string str4 = str1;//语句4 拷贝初始化,这里相当于隐式调用拷贝构造函数,而不是调用赋值运算符函数