#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;
}
原文链接: https://www.cnblogs.com/HelloCodeWrold/p/12967915.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;
也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/336303
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!