C++ protected成員存取權限
關於C++中protected的存取權限的討論已經是一個很陳舊的話題了,陳舊到大家都不願意去討論。
我再次讀《C++ Primer》的時候,其中關於protected 成員的描述是這樣的:
protected Members
The protected access label can be thought of as a blend of private and public :
- Like private members, protected members are inaccessible to users of the class.
- Like public members, the protected members are accessible to classes derived from this class.
- In addition, protected has another important property:
A derived object may access the protected members of its base class only through a derived
object. The derived class has no special access to the protected members of base type objects.
在沒有繼承的情況下,protected跟private相同。在衍生類別的時候才出現分化。
上面那段英文前兩條都很好理解,基類對象不能訪問基類的protected成員,衍生類別中可以訪問基類的protected成員。也就是說private成員是不能被繼承的,只有public,protected的成員才可以被繼承。
就是最後一條有些迷惑人,衍生類別對象如果要訪問基類protected成員只有通過衍生類別對象,衍生類別不能訪問基類對象的protected成員。
請注意 drived class和drived object:衍生類別和衍生類別對象。第一點和第二點都是針對衍生類別來說的。
對於第三點總結一句話:只有在衍生類別中才可以通過衍生類別對象訪問基類的protected成員。
#include <iostream>using namespace std;class Base{public:Base(){};virtual ~Base(){};protected:int int_pro;};class A : public Base{public:A(){};A(int da){int_pro = da;}void Print(A &obj){obj.int_pro = 24;}void PrintPro(){cout << "The proteted data is " << int_pro <<endl;}};int main(){A aObj;A aObj2(5);aObj2.PrintPro();aObj.Print(aObj2);aObj2.PrintPro(); //注釋1 //aObj.int_pro = 8;}
編譯運行結果如下:
The protected data is 5
The protected data is 24
可見,在衍生類別內部直接存取protected成員和訪問衍生類別對象基類的protected成員都是可行的。
但是若果解開注釋1.就會編譯報錯。
很多書上都說有衍生類別的情況下protected的存取權限同public。這種說法是不對的,類內部直接存取沒什麼區別,但是訪問對象基類的protected成員只能是在該類的內部。
我這裡只列舉了只有一層繼承的情況,如果有多重繼承的情況,比如三層。那麼。中介層的類的內部還可以訪問第三層類對象的基類成員,但是不能訪問第三層類自己的protected的成員。