带有 std::数组的对象类,没有默认构造函数
Class with std::array of objects without default constructors
所以让我们假设我有以下类
class NoDefaultConstructor {
NoDefaultConstructor() = delete;
...
};
我还有另一个类,它有一个类型 NoDefaultConstructor
和其他成员的数组
class Wrapper {
std::array<NoDefaultConstructor, 2> arr;
...
};
如何在构造函数中初始化数组以进行Wrapper
(也许在初始值设定项列表中使用std::intializer_list
)?
更具体地说,我是否可以将参数传递给初始值设定项列表中的数组构造函数,以便Wrapper
具有类似于以下内容的构造? 我正在考虑这样做,因为数组的大小将来可能会发生变化。
template <typename... Values>
Wrapper(Values&&... values) : arr{std::forward<Values>(values)...} {}
std::array
必须是聚合。因此,它没有重要的构造函数,但可以使用聚合初始化进行初始化。请注意,聚合初始化涉及大括号初始化列表(即初始值设定项的大括号括列表),但不涉及std::initializer_list
对象。
class Wrapper {
public:
Wrapper() : arr {MakeNoDefaultConstructor(123),
MakeNoDefaultConstructor(456)} {}
// ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ braced-init-list
private:
std::array<NoDefaultConstructor, 2> arr;
};
编辑 带有可变参数的构造函数在这里可能是可能的,如下所示
#include <array>
struct NoDefault {
NoDefault() = delete;
NoDefault(int) {}
};
struct Wrapper {
template <typename... Args>
Wrapper(int b_in, Args&&... args) : b{b_in}, a{args...} {}
int b;
std::array<NoDefault, 3> a;
};
int main() {
std::array<NoDefault, 2> a {12, 34};
Wrapper w {23, 12, 34, 19};
}
当然,这可以通过添加enable_if
来进一步严格限制。
如何在包装器的构造函数中初始化数组(可能在初始值设定项列表中使用 std::intializer_list)?
就像任何其他成员一样,但使用统一初始化,因为std::array
没有任何构造函数。
更具体地说,我是否可以将参数传递给初始值设定项列表中的数组构造函数,以使 Wrapper 具有类似于以下内容的构造?
不,为什么需要为固定数量的参数使用可变参数模板?
只。。。使用参数编写构造函数:
class Wrapper {
std::array<NoDefaultConstructor, 2> arr;
Wrapper(const NoDefaultConstructor& a, const NoDefaultConstructor& b)
: arr{ a, b }
{ }
};
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 为什么即使我调用参数化构造函数也会调用默认构造函数?
- 具有非默认构造函数的单例类
- 在 C++ 中声明 const 对象需要用户定义的默认构造函数.如果我有一个可变成员变量,为什么不呢?
- 如何处理没有默认构造函数但在另一个构造函数中构造的对象?
- 在C++中使用默认构造函数初始化对象的不同方法
- 在没有默认构造函数的情况下创建的派生对象
- 强制使用默认构造函数对成员进行未初始化的声明
- 使用默认构造函数初始化对象的不同方法
- 创建类类型的动态分配数组,其中类不得具有默认构造函数