用一個C++的小例子來說明C++中重載決議與可訪問性檢查的順序。
對於如下的類:
{
public:
double Test(double dValue) { return dValue * 13; };
private:
int Test(int iValue) { return iValue * 13; };
};
下面的函數輸出是什麼?
{
int iValue = 13;
ClxECS lx;
cout << lx.Test(iValue) << endl;
}
如果說你的答案是169,那麼你就大錯特錯了!
因爲上面的函數根本不能通過編譯!編譯器會給你一個不能訪問私有成員的錯誤。
驚奇嗎?難道編譯器不能找到類ClxECS的公有成員函數double Test(double dValue)並把實參iValue類型轉換爲double嗎?
答案是:不能!其實原因很簡單:C++中重載決議是在可訪問性檢查之前進行的。
對於上面的例子,編譯是按如下順序進行的:
首先,編譯器進行重載決議,去查找適合的成員函數(而不管查找到的成員函數是否爲public的)。這時候,編譯器理所當然的選擇參數爲int類型的Test成員函數。
然後,編譯器進行訪問性檢查。這個時候,編譯器會發現參數類型爲int的成員函數Test是類ClxECS的私有成員。那麼,編譯器就會報錯,告訴你無法訪問私有成員。