[英]Passing 2d array to a function in C with pointers
我是C语言的新手,正在学习指针。 因此,我想传递2D数组的指针。 我设法使其正常运行,但仍然收到以下警告:
||=== Build: Debug in matriz (compiler: GNU GCC Compiler) ===|
C:\Users\pauli\.dev\c\uvv\matriz\main.c||In function 'main':|
C:\Users\pauli\.dev\c\uvv\matriz\main.c|15|warning: passing argument 1 of
'printMatriz' from incompatible pointer type [-Wincompatible-pointer-types]|
C:\Users\pauli\.dev\c\uvv\matriz\main.c|4|note: expected 'int * (*)[2]' but
argument is of type 'int (*)[2][2]'|
C:\Users\pauli\.dev\c\uvv\matriz\main.c||In function 'printMatriz':|
C:\Users\pauli\.dev\c\uvv\matriz\main.c|23|warning: format '%i' expects argument
of type 'int', but argument 2 has type 'int *' [-Wformat=]|
||=== Build finished: 0 error(s), 2 warning(s) (0 minute(s), 0 second(s)) ===|
||=== Run: Debug in matriz (compiler: GNU GCC Compiler) ===|
这是我的代码:
#include <stdio.h>
#include <stdlib.h>
#define TAM 2
void printMatriz(int *matriz[TAM][TAM]);
int main()
{
int i, j, matriz[TAM][TAM];
for(i = 0; i < TAM; i++) {
for(j = 0; j < TAM; j++) {
printf("Matriz[%i][%i] = ", i, j);
scanf("%i", &matriz[i][j]);
}
}
printMatriz(&matriz);
return 0;
}
void printMatriz(int *matriz[TAM][TAM])
{
int i, j;
for(i = 0; i < TAM; i++) {
for(j = 0; j < TAM; j++) {
printf("%i\t", matriz[j][i]);
}
printf("\n");
}
}
第一个答案要使其成为指针,您需要将其括在括号内。
阅读此类定义时,应从最深的名称开始,然后从右到右依次递增,以优先次序表示。
void printMatriz(int (*matriz)[TAM][TAM])
由内而外,以名字开头:
使用原始代码:
void printMatriz(int *matriz[TAM][TAM])
由内而外的工作:
希望我的眼睛没有太多的睡眠。
现在您已经苦苦挣扎现在您已经稍微挖掘了第二个答案。
使用typedef
说明符可以通过将复杂性封装在typedef声明中来极大地简化某些定义。
typedef int matriz_t[TAM][TAM]; /* typedef simplifies referencing code */ void printTypedef(matriz_t *matriz) /* (note: now a simple pointer) */ { int i, j; for(i = 0; i < TAM; i++) { for(j = 0; j < TAM; j++) { printf("%i\t", (*matriz)[j][i]); /* still need () here */ } printf("\n"); } } int main() { int i, j; matriz_t matriztdef; /* doesn't get simpler than this */ for(i = 0; i < TAM; i++) { for(j = 0; j < TAM; j++) { printf("Matriz[%i][%i] = ", i, j); scanf("%i", &matriztdef[i][j]); } } printTypedef(&matriztdef); return 0; }
这样,您可以负担得起使用少得多的星号。 请注意,与您的代码相比,打印代码使下标的顺序相反。
#include <stdio.h>
#define TAM 2
void printMatriz(int matriz[TAM][TAM]);
int main(void)
{
int matriz[TAM][TAM];
for (int i = 0; i < TAM; i++)
{
for (int j = 0; j < TAM; j++)
{
printf("Matriz[%i][%i] = ", i, j);
if (scanf("%i", &matriz[i][j]) != 1)
{
fprintf(stderr, "failed to read an integer\n");
return 1;
}
}
}
printMatriz(matriz);
return 0;
}
void printMatriz(int matriz[TAM][TAM])
{
for (int i = 0; i < TAM; i++)
{
for (int j = 0; j < TAM; j++)
printf("%i\t", matriz[i][j]); // Reversed order of i, j
printf("\n");
}
}
样品运行:
Matriz[0][0] = 19
Matriz[0][1] = 28
Matriz[1][0] = 30
Matriz[1][1] = 41
19 28
30 41
请注意,这对于for
循环使用C99表示法,从而避免了在循环外使用变量i
和j
。 如果有问题,请在循环外恢复变量定义。
如果您确实要使用指向矩阵的指针,则可以使用代码的以下两个变体之一:
#include <stdio.h>
#define TAM 2
void printMatriz(int (*matriz)[TAM]);
int main(void)
{
int matriz[TAM][TAM];
for (int i = 0; i < TAM; i++)
{
for (int j = 0; j < TAM; j++)
{
printf("Matriz[%i][%i] = ", i, j);
if (scanf("%i", &matriz[i][j]) != 1)
{
fprintf(stderr, "failed to read an integer\n");
return 1;
}
}
}
printMatriz(matriz);
return 0;
}
void printMatriz(int (*matriz)[TAM])
{
for (int i = 0; i < TAM; i++)
{
for (int j = 0; j < TAM; j++)
printf("%i\t", matriz[i][j]);
printf("\n");
}
}
要么:
#include <stdio.h>
#define TAM 2
void printMatriz(int (*matriz)[TAM][TAM]);
int main(void)
{
int matriz[TAM][TAM];
for (int i = 0; i < TAM; i++)
{
for (int j = 0; j < TAM; j++)
{
printf("Matriz[%i][%i] = ", i, j);
if (scanf("%i", &matriz[i][j]) != 1)
{
fprintf(stderr, "failed to read an integer\n");
return 1;
}
}
}
printMatriz(&matriz);
return 0;
}
void printMatriz(int (*matriz)[TAM][TAM])
{
for (int i = 0; i < TAM; i++)
{
for (int j = 0; j < TAM; j++)
printf("%i\t", (*matriz)[i][j]);
printf("\n");
}
}
注意最后一个示例中需要的不同符号-在调用中(如您的原始代码中)以及在矩阵的使用中。
您可以通过以下方式进行操作:
#include <stdio.h>
#define TAM 2
void printMatriz(int **matriz);
int main(void)
{
int **matriz=(int**)malloc(sizeof(int)*TAM);
for (int i = 0; i < TAM; i++)
{
matriz[i]=(int*)malloc(sizeof(int)*TAM);
for (int j = 0; j < TAM; j++)
{
printf("Matriz[%i][%i] = ", i, j);
if (scanf("%i", &matriz[i][j]) != 1)
{
fprintf(stderr, "failed to read an integer\n");
return 1;
}
}
}
printMatriz(matriz);
return 0;
}
void printMatriz(int **matriz)
{
for (int i = 0; i < TAM; i++)
{
for (int j = 0; j < TAM; j++)
printf("%d ", matriz[i][j]);
printf("\n");
}
}
我想传递2D数组的指针
您可以将指针传递到2D数组的第一个元素,并使用该指针访问所有元素,如下所示:
#define TAM 2
void printMatrix(int * matrix); //function prototype
void printMatrix(int * matrix)
{
int i, j;
for(i = 0; i < TAM; i++) {
for(j = 0; j < TAM; j++) {
printf("%i\t", *(matrix + i*TAM + j));
}
printf("\n");
}
}
在您的主要功能中,您将执行以下操作:
int main()
{
int i, j, matrix[TAM][TAM];
for(i = 0; i < TAM; i++) {
for(j = 0; j < TAM; j++) {
printf("matrix[%i][%i] = ", i, j);
scanf("%i", &matrix[i][j]);
}
}
printMatrix(&matrix[0][0]); //could also do this other ways (e.g. matrix[0], *matrix) just wanted to make it explicit that you are passing a pointer to the first element of the 2D array
return 0;
}
我设法使其正常运行,但仍然收到以下警告:
||=== Build: Debug in matriz (compiler: GNU GCC Compiler) ===|
C:\Users\pauli\.dev\c\uvv\matriz\main.c||In function 'main':|
C:\Users\pauli\.dev\c\uvv\matriz\main.c|15|warning: passing argument 1 of
'printMatriz' from incompatible pointer type [-Wincompatible-pointer-types]|
C:\Users\pauli\.dev\c\uvv\matriz\main.c|4|note: expected 'int * (*)[2]' but
argument is of type 'int (*)[2][2]'|
C:\Users\pauli\.dev\c\uvv\matriz\main.c||In function 'printMatriz':|
C:\Users\pauli\.dev\c\uvv\matriz\main.c|23|warning: format '%i' expects argument
of type 'int', but argument 2 has type 'int *' [-Wformat=]|
||=== Build finished: 0 error(s), 2 warning(s) (0 minute(s), 0 second(s)) ===|
||=== Run: Debug in matriz (compiler: GNU GCC Compiler) ===|
您的警告源于对函数定义方式以及传递函数的误解。 正如其他人所述,您的函数被定义为采用指向整数int * matrix[][]
的2D指针数组的参数,并且由于数组的名称本身就是指向该数组开头的指针,因此该函数需要一个指针的指针(记住int * matrix[][]
的第一个元素将是一个指向int
的指针) ,然后将它传递给&matrix
,它是int *
(一个指向int
的指针),因为2D的第一个元素数组matrix
是一个int
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.