数组名VS数组名取地址

实验准备:

我们使用VC++6.0进行实验,首先需要打开VC++6.0的RTTI选项(默认关闭)

Project->settings->c/c++->category->c++language,Enable Run-Time TypeInfomation(RTTI)选中


测试代码:

 

#include <iostream>



using namespace std;



int main()

{

	int array[3] = {2, 4, 6};

	typedef int (*ARRAY)[3];

	int *p = array;

	ARRAY q = &array;

	//int *q = &array; //编译错误

	cout << "p = " << p << "\t\t" << typeid(p).name() << endl;

	cout << "q = " << q << "\t\t" << typeid(q).name() << endl;

	cout << "array = " << array << "\t\t" << typeid(array).name() << endl;

	cout << "&array = " << &array << "\t\t" << typeid(&array).name() << endl;

	cout << "*(p+1) = " << *(p + 1) << "\t\t" << typeid(*(p + 1)).name() << endl;

	cout << "*(q+1) = " << *(q + 1) << "\t\t" << typeid(*(q + 1)).name() << endl;

	cout << "*p+1 = " << *p + 1 << "\t\t" << typeid(*p + 1).name() << endl;

	cout << "*q+1 = " << *q + 1 << "\t\t" << typeid(*q + 1).name() << endl;

	cout << "*(*q+1) = " << *(*q + 1) << "\t\t" << typeid(*(*q + 1)).name() << endl;

	cout << "p+1 = " << p + 1 << "\t\t" << typeid(p + 1).name() << endl;

	cout << "q+1 = " << q + 1 << "\t\t" << typeid(q + 1).name() << endl;

	return 0;

}

 

 

测试结果:

数组名VS数组名取地址

 

实验结论:

1.      p和q的值相同,即array和&array是相同的,均指向相同的地址,但是两个指针的类型不同,p(array)的类型是int *(整型指针),而q(&array)的类型是int (*)[3](数组指针),这也是语句“int *q = &array;”错误的原因

2.      因为p是int *类型的指针,故p+1=0018FF40,即每次+1,地址+4,指向数组中下一个数据;而q是int (*)[3]类型的指针,故q+1=0018FF48,即每次+1,地址+12(3*4),指向下一个数组

3.      *(p+1)==p[1]==array[1]==4,这很好理解;而按照相同的逻辑,*(q+1)==q[1]==(&array)[1],此时我们可以理解成“在内存中有一个更大的数组,其元素的类型为int [3],故q[1]就等价于指向这个大数组中的第二个元素”,根据2的解释,我们知道“第二个元素”的地址为0018FF48

4.      *p+1很简单,*p就是array数组中第一个元素,*p+1即将2加1,得3;而由恒等式*&x==x知,*q=*&array=array,即*q就是数组中第一个元素的地址,*q+1即将0018FF3C加1(指针+1等价地址+4),得0018FF40,此时*q+1的类型为int*,故对*q+1进行解引用(*)就是地址所指值,故*(*q+1)==array[1]==4

 

实验图解:

数组名VS数组名取地址

 

你可能感兴趣的:(数组)