// file1.c
char str[] = "abcd";
// file2.c
#include <stdio.h>
extern char *str;
int main()
{
str[0] = 'A';
printf("%s", str);
}
编译正常,运行崩溃,为什么?
PHPz2017-04-17 14:39:30
char str[]
跟char *str
是有區別的。 str[]是數組名是個標號,str雖然是數組的首位址,但是str[]本身不佔空間,只是一個符號。而char *str
是要佔用4個位元組(64位元為8個位元組)空間的。
假設在32位元的機器上,連結器在連結的時候,將str[]開始的4個位元組(即str[0],str[1],str[2],str[3])裡面儲存的值,copy給*str
所在的4位元組記憶體空間,這意味著*str
佔用的4個位元組的記憶體空間的值變成了由"abcd"的的ascii值拼接起來組成的值。所以*str
指向了一個未知的區域,對該未知區域讀寫都有可能引發segmentation fault
。
如果你對*str
執行printf("%d",str);的話這個值應當是(little endian)
97 + 98*256 + 99*256*256 + 100*256*256*256
補充一下:上面的闡述有個錯誤,*str
其實並沒有被分配4位元組的儲存空間,因為它是extern的。形象的說*str是"熱臉貼冷屁股"贴
到str[]上去的。錯誤產生的機理是一樣的。