#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
void set_zero(int **pp, int n)
{
int *p_min = NULL;
int *p_max = NULL;
p_min = *pp;
p_max = *pp + n - 1;
int i = 0;
for(i = 0; i<n-1; i++)
{
while(p_min <= *pp && *pp <= p_max)
{
*(*pp+i) = 0;
printf("*(*pp+%d)=%d\n",i,*(*pp+i));
(*pp)++;
}
}
return;
}
int main(int argc, char *argv[]) {
int a[6] = {1,2,3,4,5,6};
int n = sizeof(a)/sizeof(int);
int *p = a;
int **pp = &p;
set_zero(pp, n);
int i = 0;
for(i =0; i<n; i++)
{
printf("a[%d]=%d\n",i,a[i]);
}
return 0;
}
通过二级指针给一个数组的初值设置为0。
对于二维数组,也就是数组的成员还是数组,又比如说字符串数组,可能会用到二级指针。
a[0]={1,2,3} |
a[1]={1,2,3} |
a[2]={1,2,3} |
a[3]={1,2,3} |
int *p = a;
int **pp = &a;
用pp变量改变p指向的数组,*pp + i = &a[i],通常会用到二级指针遍历这个二维数组中的每一个成员。
函数的传地址操作能够经过一个过程就改变变量值的原因是:直接定位到地址,对低智商的变量进行操作。
函数的传值操作,涉及到内存的拷贝,需要把值再传回来才可以,否则一切计算结果都是在被调用函数内部生成的,函数一旦结束,结果也不能返回,都是在一份拷贝上进行的,随着函数的结束而被释放(静态变量除外。。。)。
二级指针:
二级指针也是一个变量,相当于建立了一个二级指针变量,然后存储一个指针数组的第一个元素的地址,如下图。
并不是说,如果存在了一个元素为指针的数组,就自然形成了一个二级指针,这样想是不对的。
就像有一个整型数组,再建立一个整形指针,然后让整形指针指向这个整型数组,并不是这个整型数组成立之后,就自然形成了一个整形指针。