我如何添加功能来初始化此2dvector类:-
template <typename T>
class uvector2d
{
public:
uvector2d(size_t xAxis=0, size_t yAxis=0, T const &
t=T()) : xAxis(xAxis), yAxis(yAxis), data(xAxis*yAxis, t)
{}
T & operator()(size_t xNum, size_t yNum)
{return data[xNum*yAxis+yNum];}
T const & operator()(size_t xNum, size_t yNum)
const {return data[xNum*yAxis+yNum];}
private:
size_t xAxis,yAxis;
uvector<T> data;
};
使用统一的初始化,如下所示:-
vector<vector<int> > vect{ { 1, 2, 3 },
{ 4, 5, 6 },
{ 7, 8, 9 } };
我目前正在使用类似: uvector2dvect(3,3); vect(1,1)= 10864;
答案 0 :(得分:0)
您应该std::initializer_list
。简而言之,该类的功能是扩展许多相同类型的参数。您必须创建将在参数std::initializer_list
中包含的新c-tor。
从C ++ 11开始,我们有了对象初始化的新方法:
int x(0); // old way, rarely used
int y = 0; // old way, most common
int z{ 0 }; // new way, bracing initialization
制动初始化也称为统一初始化。有关此主题的更多信息,我将建议您Effective Modern C++-准确地说是第7点。
使用std::initializer_list
进行制动初始化的类型很强(与auto
的情况相同。这是您使用以下原因的原因:
vector<vector<int> > vect{ { 1, 2, 3 },
{ 4, 5, 6 },
{ 7, 8, 9 } };
您使用std::initializer_list获得了向量的构造函数:
vector( std::initializer_list<T> init,
const Allocator& alloc = Allocator() );
现在,如果我们知道括号初始化的工作原理,我们就会知道,如果我们将使用std::initializer_list
来创建任何c-tor,那么它将被调用。示例您如何做到这一点:
class ThreeNumbers
{
int x;
int y;
int z;
public:
ThreeNumbers(std::initializer_list<int> list)
{
std::initializer_list<int>::iterator it = list.begin();
x = *it++;
y = *it++;
z = *it;
}
};
答案 1 :(得分:0)
您应该实现一个构造函数,该构造函数接受初始化列表的初始化列表作为参数:
uvector2d(std::initializer_list<std::initializer_list<T>> list);
在此构造函数中,只需要将列表元素复制到一维data
成员向量中。
uvector2d(std::initializer_list<std::initializer_list<T>> list)
: xAxis(list.size()), yAxis(list.begin()->size()) {
data.reserve(xAxis * yAxis);
for (const auto& inner_list : list)
for (const auto& element : inner_list);
data.push_back(element);
}
请注意,这仅在内部列表的大小相同时才有效(这是唯一有意义的情况)。另外,您在2D向量中的元素存储似乎是 column-major ,因此我想初始化器代表一列列。如果它实际上是行列表,那么您需要转置:
uvector2d(std::initializer_list<std::initializer_list<T>> list)
: yAxis(list.size()), xAxis(list.begin()->size()) {
data.resize(xAxis * yAxis);
size_t y = 0;
for (const auto& inner_list : list) {
size_t x = 0;
for (const auto& element : inner_list); {
data[x * yAxis + y] = element;
x++;
}
y++;
}
}
我没有选择用uvector
尝试此代码,因此,如果碰巧出现任何问题,请报告。