2

假设一个给定的类A是用一个公共复制构造函数和一个私有移动构造函数定义的。如果一个函数f返回一个类型为的对象A,并f用于初始化一个类型为变量的局部实例A,那么默认情况下(因为返回的值为 a rvalue),编译器将尝试使用移动构造函数。我相信一旦编译器检测到移动构造函数是私有的,期望编译器使用复制构造函数是明智的,但是令我惊讶的是,我收到了一个编译器错误,指出移动构造函数是私有的。鉴于以下代码,我的问题如下:

 #include<iostream>

 using namespace std;

 class A
 {

    friend A f();

 public:
    A(const A&) { cout << "copy\n"; }


 private:
    A() {}
    A(A&&) { cout << "move\n"; }
 };

 A f()
 {
    A a;
    return a;
 }

 int main()
 {
    A a = f();
 }

如何更改代码(不更改 A 或 f)以便可以使用复制构造函数初始化 main 中的变量?

4

2 回答 2

1

首先执行重载决议,以选择要调用的函数。

访问检查作为后续步骤执行,检查所选函数/构造函数是否可以调用。

这是故意完成的,因此不调用私有函数(因为它私有的)。在这种情况下,让编译器选择另一个函数来调用不会有成效。

于 2012-10-19T19:27:57.190 回答
1

我会改变课程,因为它不明智。

或者从类派生或包装它。

如果你只想快速破解,你可以做

template< class Type >
Type& tempref( Type&& t ) { return t; }

然后做

A a = tempref( f() )

免责声明:编译器未触及代码。

于 2012-10-19T19:30:25.677 回答