二级指针
指针变量也是变量,是变量就有地址,那么指针变量的地址存放在二级指针中
#include <stdio.h>
int main() {
//把一级指针变量的地址取出来放入新的指针变量
int a = 10;
int* p = &a;
int** pp = &p; //pp就是二级指针
}
1. 解引用
那么如何考虑二级指针找到元素的值。
int main() {
//把一级指针变量的地址取出来放入新的指针变量
int a = 10;
int* p = &a;
int** pp = &p; //pp就是二级指针
*(*pp) = 20;
//**pp = 20; //等价写法
printf("%d\n", a);
return 0;
}
**pp 先通过 *pp 找到 p ,然后对 p 进行解引用操作: p ,那找到的是 a 。
指针数组
1. 指针数组是指针还是数组?
显然是数组。是存放指针的数组。
数组我们已经知道整形数组,字符数组。
int arr1[5];
char arr2[6];
代码如下(指针数组):
//指针数组显然是数组,其每个元素是指针,即存放指针的数组
int* arr[10]; //存放10个整形指针的数组
char* arr1[5]; //存放5个字符指针的数组
那么这样的数组元素解引用可以得到具体元素值。
int* arr[3] = {&a, &b, &c};
*(arr[0]); //这样可以得到数组里第一个元素的指针,对指针再解引用可以的到a的值。
2. 模拟二维数组
一维数组来模拟二维数组
代码如下:
int main() {
int arr1[] = { 1,2,3 };
int arr2[] = { 4,5,6 };
int arr3[] = { 7,8,9 };
int arr4[] = { 1,4,7 };
int arr5[] = { 2,5,8 };
//那么考虑将这5个数组的起始地址取出放入一根新的指针数组里
//{arr1, arr2, arr3, arr4, arr5}; 5个地址
int * arr[5] = { arr1, arr2, arr3, arr4, arr5 }; //每个元素都是int*
return 0;
}
那么要访问数组元素,做法与访问二维数组相同
for (int i = 0; i < 5; i++)
{
for (int j = 0; j < 3; j++)
{
printf("%d ", arr[i][j]);
}
printf("\n");
}