#include <iostream>
using namespace std;
class A
{
public:
A(){a = 3;}
A(const A& ra){a = ra.a; ++numOfCopy;}
void display(){cout << a << endl;}
static void showNumOfCopy(){cout << numOfCopy << endl;}
private:
int a;
static int numOfCopy;
};
int A::numOfCopy; //记得加上A::
int numOfCopy;
int main()
{
A a;
A b = A(a);
b.display();
A::showNumOfCopy();
return 0;
}
两种可能行为:
1。A(a)构造一个临时对象tmp,然后执行A b = tmp;这个属于定义,是构造对象b,而并不是赋值(赋值是已经构造好的对象的行为),所以属于“用一个类对象去构造另一个类对象的行为”,这时执行拷贝构造函数,如果并未显式提供拷贝构造函数,则系统提供一个(对于构造函数不提供的,仅在某些时候提供;系统自动提供的有默认拷贝构造函数,默认拷贝赋值符),采用“缺省按成员初始化行为”:a。对于内置类型和符合类型,直接从成员到成员的初始化;b。对于类类型的数据成员,递归a的行为构造其内部的数据成员以完成对类类型数据成员的构造。
2。A(a)看作是个多此一举的强制类型转换
根据程序验证,编译器vc6解释成行为2