有 int p[3][4];
这里 p,p+1,p+2都是对等的 如果求(p+1-p)会是多少?答案应该是1。但是如果*(p+1)-*p,答案是4;
p是指向数组的指针,*p是指向int型的指针,如果你cout<<p,cout<<*p,那么两个值是一样的,但是他们又是不一样的,一定会问,指向数组的指针,与指向int的指针区别在哪?区别在于下一跳,p+1会调一个数组的长度,*p+1会跳一个整形的长度。
*(&p[0][0]+5): &p[0][0] 是一个指向int的指针,跳5个int长度再取值;=p[1][1];
*(*(p+1)+1) : p+1是一个数组指针,*(p+1)变成int指针,跳一个,再取值;=p[1][1];
*(&p[1]+1):p[1]相当于*(p+1)是一个int指针,再取&,相当于退化到数组指针,即&p[1]=&*(p+1)=p+1,*(&p[1]+1) =*(p+1+1)=*(p+2),这里是一个int指针,指向的数值为p[2][0];即**(p+2)就是p[2][0];
实际上,如果我直接定义p[2][3], 与我在堆上申请 int *p[2];p[0]=new int[3];p[1]=new int[3]是有区别的,p+1的值与*(p+1)打印出来是不一样的;前面是存放地址,后面是该地址上的内容。直接定义的那个因为与编译器相关,p+1,*(p+1)你打印出来是一样的,但是性质不一样,前面是指向的数组,后面是指向的int,因而编译器让他们执行一跳的步长也是不同的;