int main()
{
int a[5]={1,2,3,4,5};
int *ptr1=(int *)(&a+1);
// a本身就為一個(gè)數(shù)組的地址,其值=&a[0],即數(shù)組第一個(gè)元素的地址,對(duì)a再取址
// &a = a,似乎沒(méi)什么不同,其實(shí)這里發(fā)生了對(duì)齊變更,a+1的對(duì)齊是以int為界的
// 而&a+1是以整個(gè)數(shù)組為單位的,即5個(gè)int=20字節(jié),這是關(guān)鍵!!!
// 那么&a+1實(shí)際是跨越了整個(gè)數(shù)組,可得ptr1存儲(chǔ)了數(shù)組a最后一個(gè)元素5緊跟著的一個(gè)int的地址
int *ptr2=(int *)((int )a+1);
// 同理,(int)a先將其值(地址)轉(zhuǎn)為整型值,再加一成為一個(gè)新的整數(shù)
// (int *)將這個(gè)值轉(zhuǎn)換為一個(gè)指向int型變量的指針(地址)
// ptr2即存儲(chǔ)了這個(gè)地址和指向的變量的類型
printf("%x,%x",ptr1[-1],*ptr2);
// 先解釋一下a[-1],即將數(shù)組向前偏差一個(gè)類型大小的距離
// 數(shù)組a的內(nèi)存布局(16進(jìn)制):01000000 02000000 03000000 04000000 05000000
// ptr1[-1]
// 你說(shuō)這里等于什么呢?數(shù)組a最后一個(gè)元素(5)緊跟著一個(gè)int的前面一個(gè)元素當(dāng)然就是5了。
// *ptr2
// ptr2的值為a保存的地址值的絕對(duì)值+1,假設(shè)a=1000,那么(int)a+1=1001。
// 而后將其再轉(zhuǎn)為(int *)指針,那么指針指向的內(nèi)存布局為000000 02,即向后移了一個(gè)字節(jié)
// 那么在little-enddian架構(gòu)下顯示出來(lái)為02000000,低位在高地址。
return 0;
}