我是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");
}
}
答案 0 :(得分:2)
第一个答案 要使其成为指针,您需要将其括在括号内。
阅读此类定义时,应从最深的名字开始,然后从右到右依次递增,优先。
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; }
答案 1 :(得分:1)
您可以负担得起这样少得多的星号。请注意,与您的代码相比,打印代码使下标的顺序相反。
#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");
}
}
请注意上一个示例中需要的不同符号-在调用中(如您的原始代码中)和在矩阵的使用中。
答案 2 :(得分:0)
您可以通过这种方式进行:
#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");
}
}
答案 3 :(得分:0)
我想传递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 *
的指针),因为2D数组int
的第一个元素是matrix
。