#include<iostream>
using namespace std;
int main(){
char a[5]={'g','o','o','d','\0'};
char *p=&a[0];//指针指向第一个元素
cout<<"a: "<<a<<endl;
cout<<"&a: "<<&a<<endl;
cout<<"&a[0]: "<<&(a[0])<<endl;
cout<<"&a[1] "<<&a[1]<<endl;
cout<<"a+1: "<<a+1<<endl;
cout<<"&a+1: "<<&a+1<<endl;//
//cout<<"&a+1: "<<*(&a+1)<<endl;//
cout<<"&a[0]+1:"<<&a[0]+1<<endl;//
cout<<"p: "<<p<<endl;
cout<<"p+1: "<<p+1<<endl;
return 0;
}
输出结果
数组名有时候是常量指针,是数组的第一个元素的地址
但是!数组名代表的是数组这一数据类型
关于数组名不是指针的论据如下
1.const 类型 *p = &数组名[0]
sizeof(数组名) != sizeof (p)
2.对数组名取地址得到不是(指向第一元素的指针)的指针
c++primerplus里如是说
对数组取地址时,数组名也不会被解释为其地址。等等,数组名难道不被解释为数组的地址吗?不完全如此:数组名被解释为第一个元素的地址,而对数组名取地址运算符时,得到的是整个数组的地址
结论
数组名很多情况是指针,他指向数组的第一个元素的地址,但是不要忘记他作为数组这个数据结构的基本内涵
需要注意的几个问题
1.数组名可以当作指针,但是是指针常量,故不能进行**数组名++**这种操作
2.假设char a[10]; &a[0]指向的是一个1字节内存块的地址 &a指向的是一个10字节内存块的地址
所以说&a[0] + 1表示地址+1而&a + 1表示地址+10
这个大佬的文章对我启发很深
https://blog.csdn.net/ycc541/article/details/44964723?spm=1001.2014.3001.5506