任何人都可以解释一下,为什么在我的下面的代码中,ms3 = ms1完成后,复制和赋值运算符都会在此行中被调用。在上面提到的行中,根据我的知识,只应调用重载赋值运算符。但是拷贝构造函数和赋值运算符都被调用了。请解释一下..为什么会这样?
class MyString {
private:
char* string;
public:
MyString(char *ptr = NULL);
MyString(MyString &str);
MyString & operator =(MyString str);
~MyString();
};
MyString::MyString(MyString &str) {
printf("Copy Constructor called !!!\n");
int len = strlen(str.string);
string = new char[len+1];
strcpy_s(string, len+1, str.string);
}
MyString::MyString(char* str) {
printf("Constructor called !!!\n");
if (str != NULL) {
int len = strlen(str);
string = new char[len + 1];
strcpy_s(string, len + 1, str);
}
else {
string = NULL;
}
}
MyString & MyString::operator=(MyString str) {
printf("Assignment Operator!!!\n");
if (&str == this) {
return *this;
}
delete[] string;
if (&str != NULL) {
int len = strlen(str.string);
string = new char[len + 1];
strcpy_s(string, len+1, str.string);
}
return *this;
}
MyString::~MyString() {
printf("Destructor\n");
delete[] string;
}
int _tmain(int argc, _TCHAR* argv[])
{
MyString ms = "ABC";
MyString ms1("EFG");
MyString ms2 = ms1;
MyString ms3;
ms3 = ms1;
MyString ms4 = ms3 = ms1;
return 0;
}
答案 0 :(得分:2)
赋值运算符按值获取其参数;复制构造函数用于设置该参数。
答案 1 :(得分:1)
为了避免这种情况,你需要重写你的赋值运算符,以便它像拷贝构造函数一样引用它。您还应该使用const
:
MyString(MyString const &str);
MyString & operator=(MyString const &str);