指针算术

终于开始自学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;

指针真是一个好玩又危险的东西!



你可能感兴趣的:(指针算术)