指针数组
上来先上代码:
这是指针数组的定义示例:
int *data[5] = {NULL};
指针数组的本质是一个数组,但这个数组里存储 的是指针。而且指针可以指向数组的首地址,从这个角度看它也可以模拟二维数组使用。所以它的赋值无法一次性赋值,且data无法自加,因为它是数组标识符,从某种意义上算常量;
用指针数组访问指针内任意空间:
int *data[5] = {NULL};
for (int lp = 0; lp < 5; lp++)
{
data[lp] = (int *)malloc(sizeof(int) * 4);//给单个指针申请堆空间
}
for (int lp = 0; lp < 5; lp++)
{
for (int i = 0; i < 4; i++)
{
data[lp][i] = i;//给每个指针申请的堆空间初始化
printf("data[%d][%d]=%-4d", lp, i, data[lp][i]);//当二维数组使用直接访问任意指针指向空间的任意值
}
printf("\n");
}
printf("-----------------\n");
for (int lp = 0; lp < 5; lp++)
{
for (int i = 0; i < 4; i++)
{
data[lp][i] = i;
printf("data[%d][%d]=%-4d", lp, i, data[lp][i]);
}
printf("\n");
}
for (int lp = 0; lp < 5; lp++)
{
free(data[lp]);//释放堆空间
}
数组指针
数组指针的本质是指针:它可以指向整个数组的地址;
先上图:
int data[6] = {1, 2, 3, 4, 5, 6};
int(*array)[6];
array = &data;
for (int i = 0; i < 6; i++)
{
printf("%d\n", *(*array + i));
printf("%d\n", (*array)[i]);
}
因为[ ]的优先级更高,所以必须加个括号,强调这是个指针,不然就是指针数组了,其本质是指针,所以它存储的是地址,即一般存储数组的地址。通过操作解引用,来操作地址便可访问指向数组的任意元素。
函数指针
函数指针本质也指针,存储的是函数的地址;每个函数在内存中也都有着自己对应的地址,所以也可用指针接收,并通过指针调用函数。
void *test4(char (*char_p)[], int *int_data);
int main(){
char(*char_p)[10] = "qwert";
int data[] = {1, 2, 3, 4, 5};
void *(*fp)(char(*)[], int *) = test4;
char *char_p1 =*((char(*)[])(*fp)(char_p, data));
}
void *test4(char (*char_p)[], int *int_data)
{
printf("%s\n",(*char_p));
int_data[0]=10;
return char_p;
}
本人比较懒,也很菜,这是鄙人的微薄之见,欢迎大佬指正,以及兄弟们讨论。