C++拾遺--函數重載
C++拾遺--函數重載
前言
函數重載(overloaded)似乎並不難,但仍有一些問題值得注意。下面從幾個關鍵詞入手:
正文
1.作用域
關於作用域,需要指出幾點事實
用大括號{}括起來的區域處於同一作用域,常見的有函數體、for、if語句等。同一作用域內不可出現同名的變量,若是函數同名,那就是函數重載問題。不同作用域內同名與否,沒影響。所有的函數之外的區域就是全局作用域。
首先需要指出,
同一作用域中的函數才會出現重載問題。不同作用域中的函數即使是同名,且參數類型和返回值類型一致,也是兩個不同的函數。
2.隱藏
當作用域存在嵌套關系時,隱藏現象會出現。
#include
using namespace std;
//位於全局作用域的var
int var = 0;
void print(void)
{
cout << "全局print" << endl;
}
int main()
{
//位於局部作用域的g_var會隱藏位於全局作用域的g_var
int var = 1;
//局部print同樣會隱藏全局print
auto print = [](void){
cout << "局部print" << endl;
};
//以下調用全為局部的
cout << "var = " << var << endl;
print();
//調用全局的
cout << "::var = " << ::var << endl;
::print();
cin.get();
return 0;
}
運行

vcnP0ruy49f308PT8rzM0Piy6dXSoaMKsb7KvsD9tPrC69bQo6y/ydLU1NptYWluuq/K/czlxNrV0rW9dmFyus1wcmludKOsy/nS1LX308O1xL7Nyse+1rK/tcShowrS/rLYz9bP87Htw/ejrLK7zazX99PD0/K1xM2sw/u6r8r9o6yyu8rH1tjU2LnYz7Whowo8YnI+Cgo8aDM+My5jb25zdLrN1tjU2DwvaDM+CmNvbnN0us3W2NTYtcTBqs+1ysejrNa7xNzNqLn9tdey42NvbnN0x/i31tbY1Nihowo8cHJlIGNsYXNzPQ=="brush:java;">#include
using namespace std;
void print(const char *str)
{
cout << "void print(const char *str) call" << endl;
cout << str;
}
void print(char *str)
{
cout << "void print(char *str) call" << endl;
cout << str;
}
int main()
{
char str[] = "David";
print("zhangxiang");
cout << endl;
print(str);
cin.get();
return 0;
}運行

若把void print(const char *str)改為void print(char *const str),編譯後提示錯誤:
error C2084: function "void print(char *const )' already has a body,也就是說頂層const無法區分重載。
3.覆蓋
只有虛函數才存在覆蓋(override)或者覆寫問題。覆蓋類似隱藏,但不是重載。覆蓋現象我們在虛函數中進行討論。
本專欄目錄
C++拾遺 目錄
所有內容的目錄
CCPP Blog 目錄