-
Notifications
You must be signed in to change notification settings - Fork 273
/
Copy pathmain6.cpp
114 lines (96 loc) · 3.09 KB
/
main6.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#include <iostream>
// 标示符含义:
// override,表示此虚函数必定“重写”了基类中的对应虚函数。
// final,(1)作用在虚函数:表示此虚函数已处在“最终”状态,后代类必定不能重写这个虚函数。
// (2)作用在类:表示此类必定不能被继承
// 编译器将帮你检查是否“必定”
//所以,实现多态(只有继承中的virtual重写才能实现多态(取决于等号右边new出来的对象),无virtual的重写和继承中的重载都是隐藏hide,取决于等号左边)
//就必须要有虚函数,override重写必须要是虚函数,不是虚函数应该叫隐藏而不是重写
/****************** 第一个例子 ********************/
class B1 final {}; // 此类不能被继承
// class D1: public B1 {}; // error!
class B
{
public:
// virtual void func() override // error! 指定了重写但实际并没重写,没有基类
// {
// std::cout << __FUNCTION__ << std::endl;
// }
virtual void f() const
{
std::cout << __FUNCTION__ << std::endl;
}
virtual void fun()
{
std::cout << __FUNCTION__ << std::endl;
}
};
class D : public B
{
public:
virtual void f(int) // ok! 隐藏,由于没有重写同名函数B::f,在D中变为不可见
{
std::cout << "hiding: " <<__FUNCTION__ << std::endl;
}
// virtual void f() override // error! 指定了重写但实际并没重写,类型声明不完全相同
// {
// std::cout << __FUNCTION__ << std::endl;
// }
virtual void fun() override final // ok! 指定了重写实际上也重写了,同时,指定为最终,后代类中不能再重写此虚函数
{
std::cout << __FUNCTION__ << std::endl;
}
};
class D2 : public D
{
public:
virtual void f() const // ok! 重写B::f(),同时,由于没有重写D::f(int),在D2中变不可见
{
std::cout << __FUNCTION__ << std::endl;
}
// virtual void fun() // error! 基类的此虚函数被指定为最终,不能被重写,虽然没有显示指定"override"
// {
// std::cout << __FUNCTION__ << std::endl;
// }
// virtual void fun() override // error! 基类的此虚函数被指定为最终,不能被重写
// {
// std::cout << __FUNCTION__ << std::endl;
// }
};
int main()
{
D2 d2;
D d1;
B *b = &d1;
b->f(); // B::f
b->fun(); // D::fun
//d1.f(); // error! B::f在D中不可见
d1.f(10); // hiding: D::f
//d2.f(10); // error! D::f(int)在D2中不可见
d2.f(); // D2::f
d2.fun(); // D::fun
return 0;
}
/****************** 第二个例子 ********************/
#include <iostream>
using namespace std;
class CBase{
public:
void foo(){cout << "CBase foo" << endl;}
virtual void fun(){cout << "CBase fun" << endl;}
};
class CChild:public CBase{
public:
void foo() {cout << "CChild foo" << endl;}
virtual void fun() override {cout << "CChild fun" << endl;}
};
int main()
{
CBase base1;
CBase *base2 = new CChild();
CChild c1;
base1.foo(); //CBase foo
c1.foo(); //CChild foo
base2->foo(); //CBase foo
base2->fun(); //CChild fun
}