[英]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.