为什么这种将emplace_back与已删除的复制构造函数一起使用不起作用?
Why doesn't this use of emplace_back with deleted copy constructor work?
我有一个类型,我已经从中删除了复制构造函数,我希望有一个这种类型的vector
,所以我需要通过emplace_back
创建所有元素。但是,emplace_back
似乎需要一个复制构造函数,因为编译器会发出警告,因为复制构造函数已被删除,所以无法实例化emplace_back
。为什么它需要一个复制构造函数?我认为emplace_back
的全部目的是在不复制任何内容的情况下构建vector
。我甚至可以拥有一个没有复制构造函数的对象的vector
吗?
class MyType {
public:
MyType(std::array<double, 6> a) {}
MyType(const MyType& that) = delete;
};
int main() {
std::vector<MyType> v;
std::array<double, 6> a = {1,2,3,4,5,6};
v.emplace_back(a);
}
编译器是clang/lilvm。
当vector
的内部存储增长时,它将需要将元素从旧存储移动到新存储。通过删除复制构造函数,还可以防止它生成默认的移动构造函数。
要能够调用template_back,您的类型应该是EmplaceConstructable或MoveInsertable。如果已经删除了复制构造函数,则需要为类提供一个move构造函数。(检查此项以了解template_back的要求)
MyType(MyType &&a) {/*code*/} //move constructor
如果您尝试运行以下代码:
// Example program
#include <iostream>
#include <string>
#include <array>
#include <vector>
class MyType {
public:
MyType(std::array<double, 6> a) {
std::cout<< "constructed from arrayn";
}
MyType(const MyType& that){
std::cout<< "copyn";
}
MyType(MyType&& that){
std::cout<< "moven";
}
};
int main() {
std::vector<MyType> v;
std::array<double, 6> a = {1,2,3,4,5,6};
v.emplace_back(a);
}
您将得到以下结果:
由阵列构建
实时演示
很明显,仅调用来自std::Array
的constructor
。因此,不需要copy constructor
。但同时,如果deleted
和copy constructor
,编译器将引发错误(至少在我前一秒尝试的两个编译器上)。我认为一些编译器在使用template_back时会检查copy constructor
的存在,即使在这种实际情况下没有必要,而其他编译器则不会。我不知道这里的标准是什么(哪个编译器是对的还是错的)。
相关文章:
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 当从函数参数中的临时值调用复制构造函数时
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 使用复制构造函数复制双精度数组
- C 无可行的构造函数复制类型的变量
- 没有可行的构造函数复制类型 'MyString' 的数组元素
- 编译时,复制构造函数/复制分配和正常功能调用优化之间是否存在任何区别
- 如何最小化调用列表构造函数(复制构造函数)的次数?
- C 11矢量构造函数复制与范围
- 我定义了一个非复制构造函数;复制构造函数还会被隐式定义吗
- 可以将构造函数复制为转换运算符
- 将基类指针的构造函数复制到子类
- C++树类:构造函数/复制/内存泄漏
- 如何制作这个在模板构造函数复制中使用类型定义的类型的模板
- 将构造函数复制为模板化的成员函数
- 绕过私有复制构造函数/复制赋值C++
- C++通过构造函数复制对象
- 复制构造函数 - 复制C++中的对象
- 将带unique_ptr的类的构造函数复制到作为成员的抽象类