关于用显示法初始化类对象报错的问题

上网课课后敲代码复习的时候,类内的拷贝构造函数的参数没有加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拷贝构造函数的调用

参考这篇博文(https://blog.csdn.net/bandaoyu/article/details/115741391?utm_medium=distribute.pc_aggpage_search_result.none-task-blog-2~aggregatepage~first_rank_ecpm_v1~rank_v31_ecpm-1-115741391-null-null.pc_agg_new_rank&utm_term=g%2B%2B%E4%B8%8D%E8%AE%A9%E7%BC%96%E8%AF%91%E5%99%A8%E4%BC%98%E5%8C%96&spm=1000.2123.3001.4430)
如有帮助,请采纳,谢谢。

试着把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;
}