一个关于C++拷贝构造的bug

#include <iostream>
using namespace std;

class A {
public:
    A(int a) {};
    A(const A&) = default;
}; 

class B : public A{
public:
    B(int b) : A(b) {};
    B(const A& a) : A(a){
        cout << "B copy construction" << endl;
    };
//B(const B&) = delete; };
class C : public A{ public: C(int c) : A(c) {}; C(const A& a) : A(a) { cout << "C copy construction" << endl; }; }; int main() { B b1(1); C c1(1); B b2(b1); B b3(c1); system("pause"); return 0; }

用C对象构造B对象是可以的,但是为啥用B对象构造B就没有输出“B copy construction”呢?原来B(const A& a) 并不被认为是拷贝构造函数,编译器还会生成默认的B(const B&)拷贝构造,B b2(b1)实际调用的是B(const B&),而不是声明的B(const A& a)函数。这时如果禁用默认拷贝构造B(const B&) = delete;就会发现编译不过。

转载于:https://www.cnblogs.com/redips-l/p/10619375.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值