两个数组元素的地址相减

#include <iostream>
using namespace std;

int main()
{
    int a[3];
    a[0] = 1;
    a[1] = 2;
    a[2] = 3;
    //int *p, *q;
    //p = a;
    //cout << p <<'\n';
    //cout << *p <<'\n';
    //q = &a[2];
    //cout << q << endl;
    //cout << *q << endl;
    cout << (&a[2] - &a[0]) << endl;
    //cout << (q - p) << endl;
    //cout << a[q - p] << endl;
    //cout << a[*q -*p] << endl;
}
image

此时两个地址相减得到的是这两个数据之间的间距,在反汇编窗口中可以看到两地址相减后右移了2位即除了4,这种计算相当于(地址差)/sizeof(int)。当然如果数组a[]不是int型则除数为其类型的字节数。

posted on 2015-08-12 18:23  寒叶峰  阅读(922)  评论(0编辑  收藏  举报

导航