数组名的值到底是什么?
## 1、数组名是指针
d[0]等价于(((d)+(0))),也就是等价于d.而*作为一元运算符时,它的运算对象是指针。
那么数组名就是一个类型的指针。
2、数组名不仅仅是指针
(1)作为左值,数组名表示所在的那块内存(所有数据类型的变量名标识符都有两种解释:变量的值以及变量所在的那块内存)
(2)作为右值表达式,数组确实有个值。但和基本类型变量不同的是,数组的值不是程序编写者通过代码赋予的,而是编译器在编译的时候给予的,不可以通过代码改变,而且这个值就是存储数组的内存单元的起始内存单元的编号,也就是一个地址。
通常所说的数组名的值是数组的首地址
eg.
int bjs[4];
假设数组的四个元素被储存在从1232H到1241H(16进制)这16个字节中,那么数组bjs的值就是1232H。
在C中, 在几乎所有使用数组的表达式中,数组名的值是个指针常量,也就是数组第一个元素的地址。
它的类型取决于数组元素的类型: 如果它们是int类型,那么数组名的类型就是“指向int的常量指针“。
在以下两种场合下,数组名并不是用指针常量来表示,就是当数组名作为sizeof操作符和单目操作符&的操作数时。 sizeof返回整个数组的长度,而不是指向数组的指针的长度。 取一个数组名的地址所产生的是一个指向数组的指针,而不是一个指向某个指针常量的指针。所以&a后返回的指针便是指向数组的指针,跟a在指针的类型上是有区别的