學習C 的路上一帆風順

2021-03-31 08:56:58 字數 1477 閱讀 8385

千里馬肝

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 中增加一些限...