如 int *a
和 int b[]
相同点
- a和b的值都表示一片内存区域的地址,都是使用int型进行管理
- 作为函数的形式参数没有任何区别
区别
- a是一个变量,需要分配内存空间进行存储,而b是程序中的一个标号,给编译器提供地址信息,不需要进行保存。因此可以在程序中改变a,但是无法在程序中改变b。
- 可以使用
int b[]
定义数组,如int b[] = {1, 2, 3, 4}
, 但是无法使用int *a
定义数组int *a = {1, 2, 3, 4}
//语法错误。
至于为什么编译器禁止这样的使用:{1, 2, 3, 4}
定义的数组存放在栈中(函数内定义),如果使用int b[]
接受这个定义的话,编译器可以根据b[n]
直接计算出相应的存储位置,不需要将b作为基地址进行寻址。而如果使用int *a = {1, 2, 3, 4}
的话,最终会使用a的值作为基地址再加上偏移量进行寻址。但是a的值在编译时无法获取到,因此还是需要一条赋值语句int *a = b
。这样做的话,不仅赋值耗时,而且寻址比b[n]
慢(需要多次访问内存)。得不偿失,因此编译器禁止int *a = {1, 2, 3, 4}
这样的定义方式。