2

编译以下程序时出现错误,谁能告诉我为什么编译器会给出这样的错误?

`#include <stdio.h>
void display(int **,int,int);
int main ()
{
int a[3][4]={1,2,3,4,5,6,7,8,9,0,1,6};
display(a,3,4);


return 0;
}
void display(int **a,int b,int c){

}

编译时出错

 ` ptr.c: In function ‘main’:

  ptr.c:6:1: warning: passing argument 1 of ‘display’ from incompatible pointer type [enabled by default]
  ptr.c:2:6: note: expected ‘int **’ but argument is of type ‘int (*)[4]’ `
4

3 回答 3

3

虽然 1D 数组可以转换为指针(并且会立即转换),但 2D 数组不会转换为指向指针的指针。

问题在于,在函数内部,编译器需要(至少)知道数组的宽度,以根据您提供的 2D 坐标计算内存地址。因此,您需要至少明确指定一个维度。更一般地,给定一个 N 维数组,您需要指定除第一个之外的所有坐标。

由于您使用的是 C++,因此在std::vector内部存储数组宽度的 a 周围使用一个小包装器几乎肯定会更好、更干净,这样您就可以轻松地传递它并对其进行操作。

template <class T>
class matrix { 
    size_t columns_;
    std::vector<T> data;
public:
    matrix(size_t columns, size_t rows) : columns_(columns), data(columns*rows) {}

    T &operator()(size_t column, size_t row) { return data[row*columns_+column]; }
};
于 2013-09-25T16:49:48.683 回答
2

数组不是指针。在某些上下文中,数组衰减为指向其第一个元素的指针,但仅在第一级- 数组数组衰减为指向数组的指针,但不会衰减为指向指针的指针。该规则不是递归应用的。

有关更详细的说明,请参阅C 常见问题解答。

于 2013-09-25T16:49:02.670 回答
1

的第一个参数是不能转换成a的类型,因为正如编译器所说,它们是兼容的类型。display()int[3][4]int**

但是,int[3][4]可以转换为int(*)[4]. 因此,您将 display 的第一个参数从 更改int**aint (*a)[4],然后它将正常工作。

学究式地说,在 C(和 C++)中没有像二维数组这样的东西—— a它的类型int[3][4]实际上一个数组数组,所以它可以转换为指向数组第一个元素的指针——第一个元素的类型是int[4],所以指向第一个元素的指针变为int(*)[4]. 就像一个数组类型int[100]可以转换成int*(也就是指向第一个元素的指针)。

于 2013-09-25T16:51:04.553 回答