#include <iostream>
using namespace std;
class eleA
{
int x;
public:
eleA(int m):x(m){}
eleA(eleA &a)
{
this->x = a.x;
cout << "eleA copy construction \n";
}
};
class eleB
{
int x;
public:
eleB(int m=0):x(m){}
eleB(eleB &b)
{
this->x = b.x;
cout << "eleB copy construction \n";
}
};
class C
{
private:
eleA m_a;
eleB m_b;
int m;
public:
C(eleA & a, eleB & b):m_a(a),m_b(b){} // 1
//打印2次
// eleA copy construction
// eleB copy construction
// C(eleA a, eleB b):m_a(a),m_b(b){} // 2
//打印4次
// eleB copy construction
// eleA copy construction
// eleA copy construction
// eleB copy construction
};
int main(void)
{
eleA a(1111);
eleB b(2222);
cout << "Test class initialization list:\n";
C c(a, b);
return 0;
}
這是一道突發腦抽想到的拷貝構造函數跟初始化列表結合起來的比較好玩的題目
對於1處代碼的打印結果如下
Test class initialization list:
eleA copy construction
eleB copy construction
註釋1處代碼 使用2處代碼,結果如下:
Test class initialization list:
eleB copy construction
eleA copy construction
eleA copy construction
eleB copy construction
你做對了麼?
要點如下:
對於1:
參數初始化順序與初始化表列出的變量的順序無關,它只與成員變量在類中聲明的順序有關
試試將m_a和m_b的聲明順序調換下看會發生什麼
如下:
class C
{
private:
eleA m_b;
eleB m_a;
對於2:
後2兩行的打印跟1一樣的道理 就不提了
前2行的打印順序是由於函數參數的賦值是從右到左決定的
如果你清楚了這點,那麼下面這題你也就知道結果了
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
int m=10;
int n=300;
int p=1234;
printf("%d %d %d\n", m++, --n, p+m+n);
return 0;
}