关于c++拷贝构造函数和类初始化列表的一些想法
#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;
}