指针(一级指针,二级指针)

数组
C 语言中所有的数组都可以看成是一维数组,数组传参的时候会发生降维问题,任何数组传参都会降维成指针。
一级指针
指针就是地址。
指针变量:代表地址的变量。

指针指向元素;
 int a = 10;
 int* P = &a;
 
这里面的 P 就是一个一级指针,它指向的是 a 的地址。P 里面存放的就是 a 地址的内容。

 int a = 10;
 int* p = &a;                       //  指针类型一定要与指针所指向数据的类型相同
 printf("%d\n", *p);             // *p 就是解引用,原理是通过访问 p 里面存放的地址找到这个地址所指向的元素
 
 这里输出的就是 10;

指针指向数组;

 int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
 int* p = arr;              //  数组在函数中除了 strlen  与  &  这两种情况以外,都代表首元素的地址。
 printf("%d\n", *p);  
 printf("%d\n", *(p + 1));    // 这里面 p +1 其实是 增加了 P 所指向数据类型大小字节的空间,p 开始是 1 的 地址, p +1:  因为 p 是int 型 指针,int 占 4个字节,所以要给 p 里面的地址加上 4,这样 p 的内容就变成给了 2 的地址;
 
 这里输出结果是:
  1
  2

二级指针

指针指向元素

 int a = 10;
 int* p = &a;
 int** Q = &p;

这里面的 Q 就是一个二级指针,他指向的是 p 的地址。Q 里面存放的就是 p 地址的内容。

int a = 10;
 int* p = &a;
 int** Q = &p;
 printf("%d\n", **Q);   // 这里的**Q 的意思是。先通过给Q 解引用找个 p 里面的内容,然后给 p 解引用,找到 p 所指向的内容。

这里输出的是 10;
指针指向数组
int arr[10] = { 1, 2, 3, 4, 5};
 int* p[] = { arr, arr + 1, arr + 2 ,arr+3,arr+4};
 int** Q = p;
 printf("%d\n", **Q);               
 printf("%d\n", **(Q + 1));
 printf("%d\n", **(Q + 2));
 printf("%d\n", **(Q + 3));
 printf("%d\n", **(Q + 4));

输出结果:
1
2
3
4
5

`

猜你喜欢

转载自blog.csdn.net/qq_41577616/article/details/84591403