本文小編為大家詳細介紹“C++訪問權(quán)限的示例分析”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“C++訪問權(quán)限的示例分析”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。
創(chuàng)新互聯(lián)是專業(yè)的江口網(wǎng)站建設(shè)公司,江口接單;提供做網(wǎng)站、成都網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行江口網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!
眾所周知,C++面向?qū)ο蟮娜筇匦詾椋悍庋b,繼承和多態(tài)。下面我們就先對封裝做一些簡單的了解。封裝是通過C++中的類來完成的,類是一種將抽象轉(zhuǎn)換為用戶定義類型的工具。類的定義如下:
class circle { public: //成員變量 int m_L; int m_H; public: //成員函數(shù)(方法) double get_Square() { return m_L*m_H; } }
在上面的代碼中,我們定義了一個 "circle" 類,主要包含三個部分:成員變量,成員方法和訪問控制(public, protect, private)。
public:公共權(quán)限,類內(nèi)可以訪問,類外可以訪問
protected:保護權(quán)限,類內(nèi)可以訪問,類外不可以訪問,繼承的子類可以訪問
private:私有權(quán)限,類內(nèi)可以訪問, 類外不可以訪問,繼承的子類不可以訪問
下面我們的對這三點進行測試,以加深印象:
class circle { public: int public_L; int public_H; private: int private_L; int private_H; protected: int protect_L; int protect_H; public: //成員函數(shù)(方法) circle() //通過構(gòu)造函數(shù)對成員變量進行賦值 { public_L = 20, public_H = 30; private_L = 40, private_H = 50; protect_L = 60, protect_L = 70; } double get_Square() { return private_L*private_H; } };
在定義的 "circle" 類中,由于變量 public_L,public_H 和 get_Square 都是公有權(quán)限,因此在類內(nèi)類外均可訪問,下面這兩種寫法均正確:
circle C1; //實例化類對象 double S_1 = C1.get_Square(); double S_2 = C1.public_H * C1.public_L;
但是,由于變量 private_L,private_H 均為私有權(quán)限, 因此在類內(nèi)可以訪問,即 get_Square() 能夠訪問,在類外下面的寫法是錯誤的:
int S_3 = C1.private_H * C1.private_L; //Error:成員變量不可訪問
同理,對于保護權(quán)限的變量,類內(nèi)可以訪問,類外不可訪問:
int S_3 = C1.private_H * C1.private_L; //Error:成員變量不可訪問
同樣,繼承的方式也有 public, protect, private 三種:
public:公共繼承,保持父類中成員的訪問權(quán)限,繼承到子類
protected:保護繼承,除私有權(quán)限外,父類中所有的成員都以保護權(quán)限的方式繼承到子類
private:私有繼承,父類中所有的成員都以私有權(quán)限的方式繼承到子類。
下面看一個例子:
class son1:public circle{ }; // 公有繼承,保持 circle 父類中的訪問權(quán)限不變 class son2:protected circle{ }; // 保護繼承,除去 circle 父類中私有權(quán)限,其余成員你的的訪問權(quán)限全部為保護權(quán)限 class son3:private circle{ }; // 私有繼承,父類中所有成員的訪問權(quán)限全部為私有權(quán)限
那么通過上述分析,
son1 的訪問權(quán)限與父類一致;
son2 只能在類內(nèi)訪問父類中的成員,但是他的子類中也可以通過public或者protected繼承的方式訪問到父類 "circle" 中的成員
son3 只能以私有的方式來繼承父類中的成員
所以:
son1 s1; s1.get_Square(); //訪問public權(quán)限,正確 son2 s2; s2.get_Square(); //Error:成員變量不可訪問,protected權(quán)限 son3 s3; s3.get_Square(); //Error:成員變量不可訪問,private權(quán)限
C++中,類既可以用class 定義,也可以用struct定義。struct與class唯一的區(qū)別就在于默認訪問權(quán)限不同struct默認為公共訪問權(quán)限,Class默認為私有訪問權(quán)限。舉個例子:
class a { int m_a; //class 定義,未聲明訪問權(quán)限默認為private }; struct b { int m_b; //struct 定義,未聲明訪問權(quán)限默認為public };
于是:
a c_a; c_a.m_a = 20; // Error: 成員變量不可訪問 b s_b; s_b.m_b = 20; // 正確,訪問public類型變量
C++中類的成員的權(quán)限總結(jié):
private:只能由該類的成員函數(shù),友元函數(shù)訪問,不能被該類的對象訪問。
protected:除了private外還能被子類的函數(shù)訪問,同樣不能被該類的對象訪問。
public:除了protected外,還能被該類的對象訪問。
private | protected | public | |
類的函數(shù)和友元函數(shù) | √ | √ | √ |
子類的函數(shù) | × | √ | √ |
類的對象 | × | × | √ |
繼承后的可訪問性:
private繼承后,父類中的所有方法在子類中變成private。
protected繼承后,父類>=protected的所有方法(protected,public)在子類中變成protected。
public繼承后,父類方法的屬性不變。
讀到這里,這篇“C++訪問權(quán)限的示例分析”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。