Una matriz de punteros es una matriz que almacena punteros.
analogía:
Matriz de caracteres : una matriz que almacena caracteres
char arr1[10]; // 字符数组
Matriz de enteros : una matriz que almacena números enteros
int arr2[10]; // 整型数组
Matriz de punteros: almacena punteros
char* arr3[10];// 存放字符指针的数组
int* arr4[10]; // 存放整型指针的数组
int main()
{
char* arr[3] = { "abc","bcd","cde" };
for (int i = 0; i < 3; i++)
{
printf("%c ", *(arr[i]));
}
printf("\n");
for (int i = 0; i < 3; i++)
{
printf("%s\n", arr[i]);
}
return 0;
}
arr es una matriz de punteros de caracteres y su elemento arr[i] apunta al primer elemento de la cadena. Se puede acceder al primer carácter eliminando la referencia a *(arr[i]), y arr[i] se imprime en formato %s, es decir, se imprime la cadena a la que apunta arr[i].
El resultado de la ejecución del programa anterior:
Simule una matriz bidimensional usando una matriz de punteros
int main()
{
int arr1[] = { 1,2,3,4,5 };
int arr2[] = { 2,3,4,5,6 };
int arr3[] = { 3,4,5,6,7 };
int* arr[3] = { arr1,arr2,arr3 }; // 整型指针数组
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 5; j++)
{
printf("%d ", arr[i][j]);// 等价*(arr[i]+j)
}
printf("\n");
}
return 0;
}
Resultados de:
Continúe aprendiendo contenido de puntero avanzado; consulte el siguiente artículo: Punteros de matriz