C++繼承類成員訪問權限修飾符詳解

1. 前言

C++提供瞭三個修飾符來限定類成員的被訪問權限,分別是public ,protected, private. 通過限定訪問權限,可以達到程序編寫者想要解決的安全問題和權限問題。這種權限的設置對於安全是非常必要的。

2. 不同修飾下的類成員被訪問權限

  • public:被public修飾的類成員可以在任何地方被訪問到。
  • protected:被protected修飾的類成員可以在類內部,子類內部和友元函數訪問到。但不能通過類對象訪問。
  • private:被private修飾的類成員可以在類內部和友元函數訪問到,但不能在子類和通過類對象訪問。

可以看出:

protected和private的區別是:private修飾的不能被繼承到子類種訪問。

protected和public的區別是:public修飾的可以直接通過類對象訪問。

3. 繼承時的屬性變化

他們之間經過繼承後的結合關系如下:

public protectded private
public public protected private
protected protected protected private
private private private private

4. protected的作用

加入基類中的某個函數,我們不想將其暴漏,所以不能設計為public,但又想在子類中能夠訪問到,這時就可以使用protected修飾,子類繼承時可以訪問到。

總結

本篇文章就到這裡瞭,希望能夠給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!

推薦閱讀: