使用统一初始化{}初始化2d向量

时间:2018-11-26 19:05:04

标签: c++ c++11 programming-languages 2d-vector

我如何添加功能来初始化此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;

2 个答案:

答案 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尝试此代码,因此,如果碰巧出现任何问题,请报告。