一直搞不明白数组元素指针,指针数组,字符串数组指针和字符串指针变量的关系,通过这几个代码把他们总结清楚
char i[32] = "hello";
char (*p1)[32] = &i; // 这个是字符串数组指针,保存的是字符串数组的首地址 是 h
// i的类型是 char [32], &i 的类型是 char (*) [32]
char *p2 = i; // 字符串指针变量,保存的是第一个字符的 h 地址,其他的ello放在文字常量区
// 这里的 i 其实是 &i[0],因此类型是char *
// 虽然p1 和 p2都是h的地址,但是含义不同
cout << p1 <<endl; // 这里输出的是字符串数组的地址 输出 0xf8f2dffd30 (这里是字符串数组的地址)
cout << p1+1 <<endl; // 这里虽然只是+1,但是实际跳过了32个字节 输出 0xf8f2dffd50
cout << p2 <<endl;// 输出 hello 当输出首元素地址时,由于内容在文字常量区,因此相当于遍历了p2的内容
cout << p2+1<< endl; // 输出 ello 同样,相当于从e开始遍历内容
cout << *p1 <<endl; // 输出 hello
cout << *(p1+1) <<endl;// 输出空 由于是字符串数组指针,所以+1跳过32个字节,因此变成空
cout << *(*p1+1) << endl; // 输出 e, *p1相当于取首元素地址 +1后变成第二个元素,再取内容
cout << *(p2) <<endl; // 输出 h, 字符串指针变量取内容是第一个元素
cout << *(p2+1) <<endl;// 输出 e +1后变成第二个元素
// cout << *(*p2+1) <<endl; // 这个代码运行错误,因为(*p2+1)已经输出int 了,没办法再取内容
cout << "______"<<endl;
int arr[3] = {{1},{2},{3}};
int (*p3)[3] = &arr;// 这里是 数组指针 指向的是arr数组的首地址,即是{1}
int *p4 = arr; // 这里是 数组元素的指针 指向的是arr的首元素地址,也是{1}
cout << p3 <<endl;//输出 0x7e0f3ff834 输出数组的地址(注意这个数组的地址和首元素的地址是相同的,虽然输出相同,但是意义不同)
cout << p3+1<< endl;// 输出 0x7e0f3ff840 由于p3是指向整个数组,因此+1后跨过整个数组
cout << p4 <<endl;//输出 0x7e0f3ff834 输出首元素地址 (这个是跟上面不一样的地方)
cout << p4+1 << endl; //输出 0x7e0f3ff838 由于p4是指向首元素地址,所以+1后跨过第一个元素
cout << "______"<<endl;
cout << *p3 <<endl; // 输出 0x7e0f3ff834 p3 == &arr, *p3 == *&arr, *p3 == arr,因此对数组首地址取* == 数组首元素地址
cout << *(p3+1) <<endl;// 输出 空
cout << *(*p3+1) << endl; // 输出 2, *p1相当于取首元素地址 +1后变成第二个元素,再取内容
cout << *(p4) <<endl; // 输出 1, 字符串指针变量取内容是第一个元素
cout << *(p4+1) <<endl;// 输出 2 +1后变成第二个元素
// 注意 *(*p3+1)和*(p4+1),第一个是先用*p3拿到首元素地址,然后+1,
// 然后再取*,才是第二个元素的值,而p4直接就是首元素地址,所以+1后取*即可
总结,由于数组的地址和数组首元素的地址是相同的,所以很容易搞混!!!使用的时候一定搞清楚这个指针到底是谁的指针