删除类的复制构造函数时初始化类的数组成员

时间:2016-05-18 11:33:08

标签: c++ visual-c++ visual-c++-2015

以下是我正在使用的较小版本的用例。

#include <mutex>
template<typename T = float>
class Foo
{
public:
    Foo(int x, int y):m_mutex(){}
private:
    std::mutex  m_mutex; // This is must have in my project
};

typedef Foo<float> Foo_typedef;

class Func
{
public:     
    static Foo_typedef static_array[2];
};

Foo_typedef Func::static_array[2] = { Foo_typedef(2,3), Foo_typedef(2,3) };

int main()
{   
    return 0;
}

编译完VS15 Update 2后会发出以下错误。

error C2280: 'Foo<float>::Foo(const Foo<float> &)': attempting to reference a deleted function
note: see declaration of 'Foo<float>::Foo'

我环顾四周,我怀疑这可能是其中一个原因之一。

1)删除std::mutex的复制构造函数成员

2)This我认为可能与我所看到的相似。

是哪一个?我该怎么做才能绕过VS 2015 Update 2编译器抛出的这个错误?

更新:更新了构造函数,该构造函数接受了一些需要传递给Foo_typedef的参数。

1 个答案:

答案 0 :(得分:4)

您需要使用构造函数构建元素:

Foo_typedef Func::static_array[2] = { {2, 3}, {2, 3} };

这样就没有复制或移动,因为这两个元素是就地构建的

标准说(§8.5.1/ 2 [dcl.init.aggr],重点是我的):

  

当初始化列表初始化聚合时,初始化列表的元素将被视为聚合成员的初始化 [...]。

在您的情况下,这意味着Foo_typedef(2,3)将被视为Foo_typedef初始值设定项,因此需要副本。在我给出的代码中,{2, 3}将被视为初始值设定项,并且将调用相应的构造函数(无副本)。