0

我正在使用一个 C++ 库,它要求我将它传递给一个二维数组。他们的代码示例给出了一个静态大小的数组,如下所示:

double data[][2] = {
  { 10, 20, },
  { 13, 16, },
  { 7, 30, },
  { 15, 34, },
  { 25, 4, },
};

但我需要传递运行时大小的数据。所以我试图这样做:

  // unsigned numBins  is passed in to this function and set at run time

  double** binData = new double*[numBins];
  for(unsigned i=0; i < numBins; ++i) {
    binData[i] = new double[2];
  }
  //Set the data with something like
  //   binData[7][0] = 10;
  //   binData[7][1] = 100;

  //Later, diligently delete my data...

但是,这在我正在使用的库中失败了。它以绘制一些垃圾数字的图形结束。

我知道数组不是指针。图书馆可能会在某处做“sizeof”感到困惑。

如果我无法更改此库(它是第 3 方),我该如何传递动态大小的数据?

谢谢,麦迪。

4

2 回答 2

1

可能 API 需要一个指向第一个元素的指针,它假定是二维数组的扁平表示。

所以简单的方法如下:

template<typename T>
struct FlatVectorAs2D {
private:
  size_t width;
  size_t height;
  std::vector<T> flat_vec;
public:
  std::vector<T>& base() { return flat_vec; }
  std::vector<T> const& base() const { return flat_vec; }
  size_t w() const { return width; }
  size_t h() const { return height; }
  T* operator[]( size_t index1 ) {
    return &flat_vec[index1*height];
  }
  T const* operator[]( size_t index1 ) const {
    return &flat_vec[index1*height];
  }
  FlatVectorAs2D( size_t w = 1, size_t h = 1 ):width(w), height(h) {
    flat_vec.resize(w*h);
  }
  void resize( size_t w, size_t h ) {
    width = w;
    height = h;
    flat_vec.resize(w*h);
  }
  T* raw() { return flat_vec.data(); }
  T const* raw() const { return flat_vec.data(); }
};

采用:

void api_function(double* d);
int main() {
  size_t width = 50;
  size_t height = 100;
  FlatVectorAs2D<double> buffer( width, height );
  buffer[0][1] = 1.0;
  api_function( buffer.raw() );
}

自然这将取决于 API 的工作原理。

但如果我的猜测是正确的,这将有所帮助。

于 2013-01-03T20:50:09.513 回答
0

试试这个:

typedef double two_doubles[2];

int main()
{
    two_doubles * p = new two_doubles[300];

    // ...

    delete[] p;
}

现在p指向包含 200 个单位的两个双精度数组的第一个子数组。也就是说,p[i]是一个double[2],和p[i][0]p[i][1]是它的成员元素。

(更好地使用std::unique_ptr<two_doubles[]> p(new two_doubles[300]);并忘记内存管理。)

于 2013-01-03T20:36:34.703 回答