本文章向大家介绍从底层看指针,主要包括从底层看指针使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
指针的概念:
- 指针就是变量,用来存放地址,地址唯一标识一块内存空间
- 指针大小是固定的4/8字节(32位平台/64位平台)
- 指针是有类型的,指针的类型决定指针的±整数的步长
int *p1[10];
int (*p)[10];
*的优先级比[ ]的优先级大,所以int *p1[10]的含义首先是一个数组,所以他是一个指针数组;而int (*p)[10]是一个数组指针;
int arr[10];
arr与&arr分别是什么意思?
在这里需要牢记一点:数组名在&arr和sizeof(arr)内代表整个数组,其他地方都是表示首元素地址
因此arr代表数组首元素地址,而&arr代表数组首地址,虽然值是相同的,但是含义不同;
如需证明只需打印
printf("arr+1=%p\n",arr+1);//打印结果为数组首地址+指针类型
printf("&arr+1=%p\n",&arr+1);//打印结果为数组地址+整个数组大小
void test(char **p)
{}
int main()
{
char c='b';
char *pc=&c;
char **ppc=&pc;
char *arr[10];
test(&pc);
test(ppc);
test(arr);
return 0;
}