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