数据结构课上,老师讲到如何得到一个指针的地址的时候,说到了L+i*sizeof(ElemType)和L+i,课上老师说改用前者。我回到宿舍用VS2013实验了一下,代码如下:
#include<iostream>
using namespace std;
void main()
{
int m[] = { 1, 3, 5, 7, 9, 0, 8, 6, 4, 2 };
int *p = m;
cout << "&m[1]:" << &m[1] << endl;
cout << "p+1*sizeof(int):" << p + 1 * sizeof(int) << endl;
cout << "p+1:" << p + 1 << endl;
cout << "p:" << p << endl;
}
得到的结果是与老师相反的,结果如下:
p+1的地址和m[1]的地址一样,而p+1*sizeof(int)的地址是错的。刚开始以为老师错了,
后来发现其实L+i*sizeof(ElemType)是对的,只不过在VS中,当你定义一个数据时,电
脑自己把数据类型记下了,并且自己在编译的时候会认为加一就是加一个数据类型的长
度。所以p+1就是理论上的p+1*(sizeof(int))。从结果的截图上看,p+1比p地址大4
字节,而p+1*(sizeof(int))比p大了4*4=16字节,刚刚好是4个字节的长度。