1

这是我正在处理的一个较小版本的用例。

#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;
}

编译此 VS 2015 Update 2 后会发出以下错误。

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

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

1) 复制构造函数成员 forstd::mutex被删除

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

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

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

4

1 回答 1

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}将作为初始化程序,并调用相应的构造函数(无副本)。

于 2016-05-18T11:42:27.643 回答