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