C++继承中父类和子类之间的同名覆盖
生活随笔
收集整理的這篇文章主要介紹了
C++继承中父类和子类之间的同名覆盖
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- 1 C++繼承中父類和子類的同名成員變量
- 1.1 父類和子類的同名成員變量
- 2 C++繼承中父類和子類的同名成員函數
- 2.1 父類和子類中的同名成員函數
1 C++繼承中父類和子類的同名成員變量
1.1 父類和子類的同名成員變量
思考:子類中是否可以定義父類中的同名成員?如果可以,如何區分?
父子間的沖突:
- 子類可以定義父類中的同名成員。
- 子類中的成員將隱藏父類中的同名成員。
- 父類中的同名成員依然存在于子類中。
- 通過作用域分辨符(::)訪問父類中的同名成員。
訪問父類中的同名成員:
同名變量深度分析:
2 C++繼承中父類和子類的同名成員函數
2.1 父類和子類中的同名成員函數
思考一個問題:子類中定義的函數是否能夠重載父類中的同名函數?
類中的成員函數可以進行重載,我們需要再來回顧下重載的概念:
- 重載函數的本質為多個不同的函數。
- 函數名和參數列表是唯一的標識。
- 函數重載必須發生在同一個作用域中。
我們必須知道父類和子類屬于不同的作用域,所以子類中的函數不能夠 重載父類中同名函數。
所以,對于子類和父類中的同名函數:
- 子類中的函數將隱藏父類的同名函數(跟參數列表無關)。
- 子類無法重載父類中的成員函數。
- 使用作用域分辨符訪問父類中的同名函數。
- 子類可以定義父類中完全相同的成員函數。
父子間的同名函數:
#include <iostream> #include <string>using namespace std;class Parent { public:int mi;void add(int v){mi += v;}void add(int a, int b){mi += (a + b);} };class Child : public Parent { public:int mi;void add(int v){mi += v;}void add(int a, int b){mi += (a + b);}void add(int x, int y, int z){mi += (x + y + z);} };int main() {Child c;c.mi = 100; c.Parent::mi = 1000;cout << "c.mi = " << c.mi << endl;cout << "c.Parent::mi = " << c.Parent::mi << endl;c.add(1);c.add(2, 3);c.add(4, 5, 6);cout << "c.mi = " << c.mi << endl;cout << "c.Parent::mi = " << c.Parent::mi << endl;return 0; }參考資料:
總結
以上是生活随笔為你收集整理的C++继承中父类和子类之间的同名覆盖的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C++继承中的构造与析构
- 下一篇: 2020年券商排名出炉 净利润过百亿