终于开始自学C++了,心情好激动。今天看书发现一个关于“指针算术”的有趣的小例子,感觉作为面试题会有点意思,所以想记下来。
大家看看下面这段代码会输出什么?
#include "stdafx.h"
#include <iostream>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
int jay[10]={5,2,8,4,1,2,2,4,6,8};
int* pt = jay;
pt = pt + 1;
int* pe = &jay[9];
pe = pe - 1;
int diff = pe - pt;
cout<<"diff="<<diff<<endl;
system("pause");
return 0;
}
我的第一直觉是等于4,jay[8]-jay[1]=6-2=4. 可是书上说结果是7,我一运行,果然是7.
想了好久终于想通了,原来pe-pt的含义是jay[8],jay[1]这两个元素之间的“距离”。
如果要得到4,可以这么写:
int diff = *pe - *pt;
而下面这种写法,是指针地址作为数字的差,即28=7x4:
long diff = (long)pe - (long)pt;
指针真是一个好玩又危险的东西!