淺談C++繼承中的名字查找
更新時間:2017年01月10日 09:54:55 投稿:jingxian
下面小編就為大家?guī)硪黄獪\談C++繼承中的名字查找。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
實例如下:
#include<iostream> #include<string> using namespace std; class Base { public: void func() { cout << "func() in Base." << endl; } void func(int a) { cout << "func(int a) in Base." << endl; } void func(string s) { cout << "func(string s) in Base." << endl; } }; class Derived : public Base { public: //using Base::func; void print() { cout << "func() in Derived." << endl; } }; int main() { Derived d; d.Base::func();//指定基類版本 d.func(); d.func(12);//error,可在派生類中添加using Base::print; d.func("abc");//error,可在派生類中添加using Base::print; system("pause"); return 0; } //一個對象,引用,指針的靜態(tài)類型決定了該對象哪些成員可見。 //派生類作用域嵌套在基類作用域中 //派生類成員將屏蔽同名的基類成員 //如果派生類想通過自身類型使用的基類中重載版本,則派生類必須要么覆蓋所有重載版本,要么一個也不覆蓋。 //利用using聲明可把基類中的所有重載版本都添加到派生類作用域中 //名字查找先于類型檢查,如果在派生類中找到了調(diào)用的函數(shù)名,則不會繼續(xù)向上查找,接著進行類型檢查
以上這篇淺談C++繼承中的名字查找就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
C++實現(xiàn)LeetCode(104.二叉樹的最大深度)
這篇文章主要介紹了C++實現(xiàn)LeetCode(104.二叉樹的最大深度),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07