1、友元函式
為什麼會有友元函式?
結合著類的特性和類中一般成員函式,我們可以這樣理解:類具有封裝和資訊隱藏的特性。只有類的成員函式才能訪問類的私有成員,程式中的其他函式是無法訪問私有成員的。非成員函式可以訪問類中的公有成員,但是如果將資料成員都定義為公有的,這又破壞了隱藏的特性。另外,應該看到在某些情況下,特別是在對某些成員函式多次呼叫時,由於引數傳遞,型別檢查和安全性檢查等都需要時間開銷,而影響程式的執行效率。
為了解決上述問題,提出一種使用友元的方案。友元是一種定義在類外部的普通函式,但它需要在類體內進行說明,為了與該類的成員函式加以區別,在說明時前面加以關鍵字friend。友元不是成員函式,但是它可以訪問類中的私有成員。友元的作用在於提高程式的執行效率,但是,它破壞了類的封裝性和隱藏性,使得非成員函式可以訪問類的私有成員。
友元函式的特點是能夠訪問類中的私有成員的非成員函式。友元函式從語法上看,它與普通函式一樣,即在定義上和呼叫上與普通函式一樣。
友元函式的使用
例如:cb.cpp需要訪問ca.h的私有變數
ca.h
#pragma once
#include
#include
using
namespace
std;
class cb;
class ca
protected:
string name;
void setname(string s)
public:
void print()
friend
void test(ca& a); //申明cb類的test()函式作友元,允許它訪問私有保護成員
};
cb.cpp
#include"ca.h"
using
namespace
std;
class ca; //事先申明ca類,確保cb類的定義不出錯
class cb ;
void test(ca& a)
int main ( )
執行結果:
2、友元類
當乙個類作為另乙個類的友元時,這就意味著這個類的所有成員函式都是另乙個類的友元函式。
ca.h:
#pragma once
#include
#include
using
namespace
std;
class ca
friend
class cb;
private:
void printdata() const
int mx;
int my;
};
cb.cpp:
#include
#include
#include"ca.h"
using
namespace
std;
//class ca; //事先申明ca類,確保cb類的定義不出錯
class cb
void showdata() const
};int main ( )
使用友元類時注意:
(1) 友元關係不能被繼承。
(2) 友元關係是單向的,不具有交換性。若類b是類a的友元,類a不一定是類b的友元,要看在類中是否有相應的宣告。
(3) 友元關係不具有傳遞性。若類b是類a的友元,類c是b的友元,類c不一定是類a的友元,同樣要看類中是否有相應的申明
總結起來:
(1)友元關係不可以繼承,但對已有的方法來說訪問許可權不改變。
(2)如果改寫基類的方法則訪問許可權改變
(3)友元關係不具有傳遞性
若類b是類a的友元,類c是b的友元,類c不一定是類a的友元。
友元 友元函式 友元類和友元成員函式 C
有些情況下,允許特定的非成員函式訪問乙個類的私有成員,同時仍阻止一般的訪問,這是很方便做到的。例如被過載的操作符,如輸入或輸出操作符,經常需要訪問類的私有資料成員。友元 frend 機制允許乙個類將對其非公有成員的訪問權授予指定的函式或者類,友元的宣告以friend開始,它只能出現在類定義的內部,友...
友元 友元函式 友元類和友元成員函式 C
有些情況下,允許特定的非成員函式訪問乙個類的私有成員,同時仍阻止一般的訪問,這是很方便做到的。例如被過載的操作符,如輸入或輸出操作符,經常需要訪問類的私有資料成員。友元 frend 機制允許乙個類將對其非公有成員的訪問權授予指定的函式或者類,友元的宣告以friend開始,它只能出現在類定義的內部,友...
C 友元 友元函式 友元類和友元成員函式
有些情況下,允許特定的非成員函式訪問乙個類的私有成員,同時仍阻止一般的訪問,這是很方便做到的。例如被過載的操作符,如輸入或輸出操作符,經常需要訪問類的私有資料成員。友元 frend 機制允許乙個類將對其非公有成員的訪問權授予指定的函式或者類,友元的宣告以friend開始,它只能出現在類定義的內部,友...