C++中重載決議與可訪問性檢查的順序

用一個C++的小例子來說明C++中重載決議與可訪問性檢查的順序。

 

    對於如下的類:

class ClxECS
{
public:
    
double Test(double dValue) { return dValue * 13; };

private:
    
int Test(int iValue) { return iValue * 13; };
};

    下面的函數輸出是什麼?

void ECS_test()
{
    
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的私有成員。那麼,編譯器就會報錯,告訴你無法訪問私有成員。

 

 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章