上网课课后敲代码复习的时候,类内的拷贝构造函数的参数没有加const,然后我用显示法来对类对象进行初始化的时候就报错了。我不理解为什么必须要加const
#include<iostream>
using namespace std;
class Person
{
public:
Person(int a)
{
age = a;
cout << "Person有参构造函数的调用" << endl;
}
//拷贝构造函数
Person(Person& p)
{
cout << "Person拷贝构造函数的调用" << endl;
age = p.age;
}
int age;
};
int main()
{
Person p1 = Person(10);
Person p2 = Person(p1);
system("pause");
return 0;
}
我试着查找匿名对象是不是常量,但是匿名对象的生存周期就在那一行。而且为什么 Person p1 = Person(10);这里没有用到拷贝构造函数,他也说没有合适的拷贝构造函数呢
麻烦各位帮帮忙!解答我的疑惑,谢谢了!
依次回答一下题主的问题
1.拷贝构造函数加上const,这里其实加不加都行,但是根据你加不加,在调用拷贝构造函数的时候就必须要参数类型匹配,比如这句代码Person p1 = Person(10);
,在linux下使用g++编译器是编译不过的,因为Person(10)首先生成了一个Person类型的临时值(右值),但是拷贝构造的参数是Person&类型,非const的引用是无法绑定右值的,所以一般最好加上const,对于const的用法,C++是能加const就都加上,一方面为了让人明白这是一个常量不会发生更改,一方面编译器也会进行优化。
2.加上explict会报错,参考这个https://blog.csdn.net/gghhb12/article/details/123548985
3.为什么 Person p1 = Person(10);这里没有用到拷贝构造函数,是因为编译器优化掉了,在linux下,通过g++编译时加上-fno-elide-constructors选项就能看到如下打印
[root@localhost czh]# g++ main.cpp -fno-elide-constructors
[root@localhost czh]#
[root@localhost czh]#
[root@localhost czh]# ls
456.txt a.out main.cpp rest_rpc test
[root@localhost czh]# ./a.out
Person有参构造函数的调用
Person拷贝构造函数的调用
Person拷贝构造函数的调用
Person拷贝构造函数的调用
试着把int age;这行代码放在构造函数的前面差不多就是第七行。
Person p1(10);
Person p2(p1);
这样就行了
加const是为了防止你修改东西,你可以传入指针,就不用加const了
#include<iostream>
using namespace std;
class Person
{
public:
Person(int a)
{
age = a;
cout << "Person有参构造函数的调用" << endl;
}
//拷贝构造函数
Person(Person *p)
{
cout << "Person拷贝构造函数的调用" << endl;
age = p->age;
}
int age;
};
int main()
{
Person *p1 = new Person(10);
Person p2 = Person(p1);
system("pause");
return 0;
}