C 的乙個問題的理解(私有變數成員)

2021-06-25 17:36:14 字數 1704 閱讀 6551

這個題目很奇怪啊,今天下午在看拷貝建構函式的時候,突然看到了很奇怪的一句話:

[cpp]view plain

copy

class

cexample  

~cexample()  

cexample(const

cexample&);   

void

init(

intn)  

private

:  char

*pbuffer;   

intnsize;  

};  

cexample::cexample(const

cexample& rightsides)     

感嘆號部分我很奇怪,不是不允許物件許訪問私有變數成員麼?怎麼回事,而且還能編譯通過。

1.為什麼物件a可以直接訪問私有的x(a.x)成員見

給出了乙個解答:因為a(const a&a)是他的成員函式。

在我的例子也是如此:cexample::cexample(const cexample& rightsides)是cexample的成員函式,所以可以訪問同型別物件的私有成員。即righsides.nsize的呼叫可以編譯用過,但是,你在main函式裡面直接寫上:

[cpp]view plain

copy

intmain(

intargc, 

char

* argv)    

編譯器肯定是報錯,提示你nsize是私有變數,不允許物件進行訪問。

隨後,我又做了乙個實驗:

[cpp]view plain

copy

#include 

using

namespace

std;  

class

t;  

class

ctest  

;  int

print1(

const

ctest &);  

intprint2(

const

t&);  

private

:  int

m_data;  

};  

ctest::ctest()  

ctest::ctest(const

ctest& arg)  

ctest & ctest::operator = (const

ctest & arg)  

intctest :: print1(

const

ctest & arg)  

intctest::print2(

const

t& arg)  

intmain()    

請注意print()、print1()、print2()的區別;

print()自然不用說,成員函式訪問類的私有變數,編譯通過;

print1():print1是ctest類的成員函式,而print1的形參是const ctest& arg,arg的型別就是ctest,根據成員函式可以訪問私有變數,故編譯通過

print2():print2是ctest類的成員函式,但是print2的形參型別是t,不是ctest,print2不是t的成員函式,不能訪問類的私有變數,故編譯不能通過

C 的乙個問題的理解(私有變數成員)

這個題目很奇怪啊,今天下午在看拷貝建構函式的時候,突然看到了很奇怪的一句話 class cexample cexample cexample const cexample void init int n private char pbuffer int nsize cexample cexample...

C 的乙個問題的理解(私有變數成員)

class cexample cexample cexample const cexample void init int n private char pbuffer intnsize cexample cexample const cexample rightsides 感嘆號部分我很奇怪,不是...

C 乙個類呼叫另乙個類的成員變數 成員函式

有時候,兩個類之間並沒有繼承的關係,但是其中乙個類需要引用另乙個類中的成員變數或者成員函式。怎樣辦到呢?假設已經新建了兩個類a b。class a class b 現在需要在類a的成員函式中呼叫類b的成員變數b nadd b x,使得a nadd與b nadd相加,那麼只需要在類a的.cpp檔案中包...