以下是我正在使用的较小版本的用例。
#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
的参数。
答案 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}
将被视为初始值设定项,并且将调用相应的构造函数(无副本)。