下面對C++中訪問控制技術說明與介紹,C++中訪問控制分為兩大類,第一種為:private,public,protected的訪問范圍,第二種為:繼承後方法屬性變化,歡迎大家學習參考。。。
第一:private,public,protected的訪問范圍:
private: 只能由該類中的函數、其友元函數訪問,不能被任何其他類及其子類的函數訪問,該類的對象也不能訪問. protected: 可以被該類中的函數、子類的函數、以及其友元函數訪問,但不能被該類的對象訪問 public: 可以被該類中的函數、子類的函數、其友元函數訪問,也可以由該類的對象訪問注:友元函數包括兩種:設為友元的全局函數,設為友元類中的成員函數。
第二:類的繼承後方法屬性變化:
使用private繼承,父類的所有方法在子類中變為private; 使用protected繼承,父類的protected和public方法在子類中變為protected,private方法不變; 使用public繼承,父類中的方法屬性不發生改變;
再次提到:可以提供訪問行為的主語為“函數”。類體內的訪問沒有訪問限制一說,即private函數可以訪問public/protected/private成員函數或數據成員,同理,protected函數,public函數也可以任意訪問該類體中定義的成員public繼承下,基類中的public和protected成員繼承為該子類的public和protected成員成員函數或數據成員),然後訪問仍然按類內的無限制訪問。
對於類域范圍內,成員函數訪問無所謂訪問限制。對於繼承情況下的基類private成員,在派生類中仍然繼承了下來,只不過它不能直接訪問,即使在類裡也不行,更不用說是類對象了。
其實,對於這個問題,Bjarne已經宣傳了十年。早在99年的時候Bjarne就寫了“Learning C++ as A New Language”,並在好幾篇技術訪談這裡,這裡,這裡,還有這裡)裡面提到如何正確對待和使用C++中訪問控制中支持的多種抽象機制的問題。Andrew Koenig也寫了一本現代C++教程《Accelerated C++》這本書後面還會提到)。然而這麼多年來,C++社群的狀況改善了嗎?就我所知,就算有改善,也是很小的。
學習者還是盲目鑽語言細節,只見樹木不見森林;網上還是彌漫著各種各樣的“技術”文章和不靠譜的“學習C++的XX個建議”;一些業界的有身份的專家還是在一本接一本的出語言孔乙己的書寫一些普通程序員八輩子用不著的技巧和碰不著的角落);
而業界真正使用C++的公司在面試的時候還總是問一些邊邊角角的細節問題,而不是考察編程的基本素養不,掌握所有的語言細節也不能讓你成為一個合格的程序員)。這個面試理念是錯誤的,估計其背後的推理應該是“如果這個家伙不知道這個細節,那麼估計他對語言也熟悉不到哪兒去;
而如果他知道,那麼雖然他可能並不是好的程序員,但我們還是能夠就後一個問題進一步測試的”,這個理念的問題在於,對語言熟悉到一定程度什麼程度後面會具體建議)就已經可以很好的編程了剩下的只需查查文檔);
而很多公司在測試“對語言熟悉程度”的時候走得明顯太遠了比如,問臨時對象生命期和析構順序當然是無可厚非的,但問如何避免一個類被拷貝或者如何避免其構建在堆上?);當然,有些語言知識是必須要提前掌握的,具體有哪些後面會提到,面試的時候並非不能問語言細節,關鍵是“問哪些”。