从底层看指针

本文章向大家介绍从底层看指针,主要包括从底层看指针使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

指针的概念:

  1. 指针就是变量,用来存放地址,地址唯一标识一块内存空间
  2. 指针大小是固定的4/8字节(32位平台/64位平台)
  3. 指针是有类型的,指针的类型决定指针的±整数的步长
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;
}
相关推荐
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页