千里馬肝
class a
int m_i; };
int main()
分別說說吧:
1. a a = 0;
首先, ***piler認為這樣寫是不符合規矩的, 因為a = a才是正常行為。
但是她並不放棄, 通過搜尋, 發現a可以根據乙個int構造, 同時這個a(int i)沒有用explicit修飾過。
那麼a a = 0; 這樣的一句話隨即轉變成:
a tmp(0);
a a = tmp;
需要說明的是, a a = tmp是呼叫的copy ctor, 雖然class a中並沒有, 但是通常不寫copy ctor的話,
***piler都會生成乙個memberwise assignment操作性質的ctor, 底層實現通常會以memcpy進行。
2. a = 10;
首先, 這樣同ctor的情況一樣, ***piler無法直接進行操作。
類推, 等同於**:
a tmp(10);
a = tmp;
需要注意的是, a = tmp是呼叫的assignment操作, 同ctor一樣,我們自己不寫, 編譯器同樣進行
memberwise assignment操作。
3. fn(a a)
同樣, fn(10)也是不對的, 但是"按照慣例", 呵呵, 會有:
a tmp(10);
fn(tmp);
另外, 為你解惑:
copy ctor的寫法只能是t::t(const t &);
而assignment的寫法可以多變, 即任意. 以t為例,
可以有
t &operator = (int n);
也可有
t &operator = (const char *);
當然, 你要確認如此的定義是對t而言有意義.
然後, 上述a = tmp, 即呼叫的預設的、標準的、自動生成的t &operator = (const t &).
開銷是會有乙個臨時的a tmp生成, 然後memcpy.
但如果你自已寫了t &operator = (int n), 那麼a = 10即意味著a.m_i = 10.
當然, 以開銷而言要視你的t &operator = (int n)是否為inline了.
對於explicit, 當修飾explicit a(int i) : m_i(i){}, 那麼即告訴***piler不要在私底下做那麼多的轉換動作.
而且自動生成如a tmp(0)這樣的東西是我們不想要的, 因為某些情況下自動轉換這種行為是錯誤的.
最後, 相關此類問題, 還有乙個話題, 即class a可以有operator int(), 會在
fn(int n){}
a a(3);
fn(a)
起到魔術般的作用. 關於這個, 留給你自己看看書吧:)
最後,祝學習c++的路上一帆風順。good luck~
網際網路公司的如履薄冰 從不一帆風順的發布
辛苦了一晚上,系統終於上線了。儘管在計畫的時候為發布預留了時間,但實際上我們依然處於緊張的程序中,可能唯一值得慶幸的是,不需要凌晨3點才能回家。每次的發布都注定不會平坦,鮮有一舉成功的案例。昨晚的發布我心存僥倖,回想之前詳盡的測試和試用,這次應該不會再有什麼問題了吧。早上9點半,我還在暖和的床上被 ...
python學習之路上的一些小筆記
在學習python的過程中,我積累了不少的筆記以及練習,但是疏於整理正好時至春節放假之際,再加上新型冠狀病毒的肆虐。各個村 小區都已經封鎖,實在無聊對我考完研究生之後學習python到現在的筆記進行記錄一下,這是在家裡學習的一部分,還有在學校的一部分寫在這裡作為提醒寫在這裡,以及進行時不時的回憶 程...
C 的學習(一)
1 在c 中用字段和屬性來表示靜態特徵,用方法來描述類動態的行為 public class person set public int age set public string set 屬性相當於是給字段新增了一層保護套,要新增則要走get 要修改則要走set 可以在get 和set 中增加一些限...