如何使用c ++中的指针将未知大小的多维数组传递到函数中?

时间:2011-05-25 18:48:46

标签: c++ arrays function pointers

就像问题所说,我试图将多维数组传递给函数,将其打印到工程项目的文件中。输入数据的格式不能更改,所以请不要建议我只是将其输入为不同的数据类型。

这个特殊的函数预期一个二维数组(虽然我有其他三维后的数据),直到运行时才知道数组的大小。我知道我必须使用指针分别指向数组的每一行,但我不知道将它传递给函数的语法是什么。在下面的代码中,有问题的数组是'block'。主要功能只是我尝试使其工作的一个小测试示例:

#include<fstream>
using namespace std;

void of_write_blocks(string filename, string block_type[], int **block,
            int grid[][3], string grade_type[], int grade[][3], int n_blocks, int m[])
{
    ofstream file_out(filename.c_str(),ios::app);
    file_out<<"\nblocks\n(\n";

    for(int i=0;i<n_blocks;++i) {
            file_out<<"   "<<block_type[i]<<" ( ";
                    for(int j=0;j<m[i];++j)
                            file_out<<block[i][j]<<" ";
            file_out<<") ( ";
            file_out<<grid[i][0]<<' '<<grid[i][1]<<' '<<grid[i][2]<<" ) ";
            file_out<<grade_type[i]<<" ( ";
            file_out<<grade[i][0]<<' '<<grade[i][1]<<' '<<grade[i][2]<<" )\n";
    }
    file_out<<");\n";
}


//testing example:
int main()
{       
    int block[6][9];
    for(int i=0; i<6;++i) 
            for(int j=0; i<9;++j)
                    block[i][j] = i*j;

    int grid[6][3];
    for(int i=0; i<6;++i)
            for(int j=0; i<3;++j)
                    block[i][j] = i*j;


    int grade[6][3];
    for(int i=0; i<6;++i) 
            for(int j=0; i<3;++j)
                    block[i][j] = i*j;

    string grade_type[6] = {"simpleGrading"};
    string block_type[6] = {"hex"};
    int m[6] = {8};
    int n_blocks = 6;

    of_write_blocks("name",block_type,block,grid,grade_type,grade,n_blocks,m);
}       

任何帮助表示赞赏!

4 个答案:

答案 0 :(得分:5)

你做不到。多维数组是语法糖,并直接编译到对数组进行操作的代码中,该数组是单个内存块。尺寸不作为参数传递到函数中,也不作为数组的一部分传递给函数,因为事情是在例如Java或C#。

如果你需要函数中数组的维度,你需要只接受指向数组的第一个元素和维度的指针,并进行乘法和加法以获得正确的索引。< / p>

或者,使用像std::vector<std::vector<block>>这样的东西,它将维度作为对象的一部分传递,而不是内置数组。

答案 1 :(得分:2)

如果您安装了Boost,请查看Boost Multi-Array

答案 2 :(得分:0)

为清楚起见,我从您的示例中删除了所有不相关的代码。

#include <iostream>
#include <fstream>

using namespace std;

void of_write_blocks(int **block, int bh, int bw){

  for(int i = 0; i < bh; ++i)
    for(int j = 0; j < bw; ++j)
      cout << block[i][j] << " ";
  cout << endl;
}

int main(){       

  int bh, bw;
  cin >> bh >> bw;

  int** block;
  block = new int*[bh];
  for(int k = 0; k < bh; k++)
    block[k] = new int[bw];

  // initialize the array
  for(int i = 0; i < bh; i++)
    for(int j = 0; j < bw; j++)
      block[i][j] = (i*bw) + j;

  of_write_blocks( block, bh, bw);
}       

主要是我们创建一个2D数组并初始化它。然后我们将它传递给of_write_block,它打印数组。那是你想做的吗?

答案 3 :(得分:0)

为什么不能使用数组的引用。见下面的例子:

char c[10];
int i[10][20];
double d[10][20][30];

写一个包装器函数,如下所示:

template<typename T, int SIZE>
void Array (T (&a)[SIZE])
{}
template<typename T, int SIZE1, int SIZE2>
void Array (T (&a)[SIZE1][SIZE2])
{}
template<typename T, int SIZE1, int SIZE2, int SIZE3>
void Array (T (&a)[SIZE1][SIZE2][SIZE3])
{}

这只是一个示例,用于演示在没有任何复制的情况下优雅地接收数组的语法,并避免混淆指针。此外,如果您知道自己仅用于int,则只需删除类型名称并明确提及int即可。即。

template<int SIZE>
void Array (int (&a)[SIZE]); // explicitly mention int