先來看一段代碼
#include <stdio.h>
char c1,c2,c3;
char *cp;
void setup()
{
c1='a';//97
c2='b';//98
c3='c';//99
cp=&c1;
}
int main()
{
setup();
printf("cp=%p\n",cp);
printf("&c1=%p\n",&c1);
printf("&c2=%p\n",&c2);
printf("&c3=%p\n",&c3);
printf("(cp+1)=%p\n",(cp+1));
printf("*cp+1=%d\n",*cp+1);
return 0;
}
打印結果:
cp=0000000000407979
&c1=0000000000407979
&c2=0000000000407978
&c3=000000000040797A
(cp+1)=000000000040797A
*cp+1=98
發現c1、c2、c3的地址並不是有序的,而是c1->c3->c2;
這樣帶來一個問題,對c1地址+1的時候得到的並不是通常認爲的c2的地址,而是c3的地址。這感覺有點奇怪了。內存的生長居然是隨機不連續的