数组名进行类型强制转换的问题

int main(void)
{
int a[4] = {1, 2, 3, 4};
int *ptr1=(int *)(&a+1);
int *ptr2=(int *)((int)a+1);
printf("%x, %x/n", ptr1[-1], *ptr2);
return 0;
}

为什么ptr2指向a[0]的第二个字节?
个人理解是数组名a是指向a[0]的指针,强制转换为int型变量,再加1,就相当于将原来所存放a[0]的地址当作一个int型数,再进行加1的算术运算,再强制转换为int型指针。请问是这样理解的吗?

思路正确。在32机上可以实现预期。

数组名a是数组的首地址没错,另外明确的是它是一个int型的指针,如果指针直接进行++操作,一次跳跃的是4个字节。
但你先把指针强转成一个整形数,虽然这也没错,因为指针本来就是一个整型值,但是你加1这时候是往后移动了一个字节。明白否?

数组名a是数组的首地址没错,另外明确的是它是一个int型的指针,如果指针直接进行++操作,一次跳跃的是4个字节。
但你先把指针强转成一个整形数,虽然这也没错,因为指针本来就是一个整型值,但是你加1这时候是往后移动了一个字节。明白否?

这不是一个好习惯。。。指针加1和数值加1是不一样的。。。。

真想实现这种功能的话。union { int a; char b[4];}