运算和阵列

因为短是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;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值