因为短是2个字节,每个地址不同于2。
很难得看到+和–用这样的方式与指针运算符。然而,更常见的是看到+ +或-算子被用来增加或减少一个指针指向数组中的下一个或前一个元素。
指针的算术运算和阵列
如果是一个指针,指向数组的第一个元素(元素0)的阵列,并添加1到指针已经返回下一个对象,然后排列+ 1点必须到二元(1元)的阵列!我们可以验证实验,这是真的:
1
2
int anArray[5] = { 9, 7, 5, 3, 1 };
cout << *(anArray+1) << endl; // prints 7
圆括号是必须确保运算符的优先级是正确的-运算符*相比具有高优先级的操作符+。
注:*(系列1)具有相同的效果作为关联数组[ 1 ]。事实证明,数组索引运算符([])实际上是一个隐式指针添加和取消引用!它只是看起来更漂亮。
我们可以用一个指针和指针运算遍历数组。虽然不常这样做(使用指标通常更容易阅读,不易出错),下面的例子去显示它是可能的:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
const int nArraySize = 7;
char szName[nArraySize] = "Mollie";
int nVowels = 0;
for (char *pnPtr = szName; pnPtr < szName + nArraySize; pnPtr++)
{
switch (*pnPtr)
{
case 'A':
case 'a':
case 'E':
case 'e':
case 'I':
case 'i':
case 'O':
case 'o':
case 'U':
case 'u':
nVowels++;
break;
}
}
cout << szName << " has " << nVowels << " vowels" << endl;