指针与数组
1. 指针表示法和数组表示法
数组完全可以使用指针来访问, array[3] 和 *(array+3) 等同
#include <iostream>
using namespace std;
int main(void) {
int array1[10] = { 1,2,3,4,5,6,7,8,9,10 };
cout << "指针表示法" << endl;
for (int i = 0; i < 10; i++) {
cout << *(array1 + i) << " ";
}
cout << endl << "数组表示法" << endl;
for (int i = 0; i < 10; i++) {
cout << array1[i] << " ";
}
return 0;
}
2. 存储指针的数组
定义: 类型 *指针数组名[元素个数] ;
#include <iostream>
using namespace std;
int main(void) {
int array1[10] = { 1,2,3,4,5,6,7,8,9,10 };
int* p[2];//定义一个有两个元素的指针数组,每个元素都是一个指针变量
p[0] = &array1[0];
p[1] = &array1[1];
cout << *p[0] << " " << *p[1] << endl;
return 0;
}
3 - 指针和二维数组
1. 指向数组的指针
int (*p)[3]; //定义一个指向三个成员的数组的指针
访问元素的两种方式:
数组法: (*p)[j]
指针法: *((*p)+j)
#include <iostream>
using namespace std;
int main(void) {
int array1[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 };
int(*p)[4];//定义一个指向四个成员的数组的指针
p = &array1[0];//p指向了array1的第一层的四个元素的数组a[0][0] a[0][1] a[0][2] a[0][3]
cout << "使用数组法" << endl;
for (int i = 0; i < 4; i++) {
cout << (*p)[i] << " ";
}
cout << endl << "使用指针法" << endl;
for (int i = 0; i < 4; i++) {
cout << *((*p) + i) << " ";
}
cout << endl;
cout << "使用p访问全部元素:" << endl;
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 4; j++) {
cout << (*p)[j] << " ";
}
p++; //这里的++的偏移量是整个指针数组的大小,
//因为数组的大小是在一起的,所以偏移后,p是指向下一层四个元素的数组
cout << endl;
}
return 0;
}