Cast a type with a small memory space to a bigger one
這是一個很常見的錯誤,可是我還是犯了 (...sigh) 我當然不是在下面的程式碼犯錯囉,但因為犯錯的程式是工作上的程式,不能貼出來,所以稍作整理,寫出下面的那個「錯誤」程式碼,以資提醒... (為甚麼我有再犯的預感 ...) 下面的程式哪裡有問題: #include "stdio.h" #include "stdlib.h" struct test { unsigned char a; unsigned char b; unsigned char c; }; int main() { struct test tmp; printf("Please enter three number.\n"); printf("Each number should be 0~255\n"); scanf("%d %d %d", &(tmp.a), &(tmp.b), &(tmp.c) ); printf("%d %d %d\n", tmp.a, tmp.b, tmp.c); return 0; } 當我們輸入 1 2 3,顯示也是正常的 1 2 3,看起來一點問題也沒有。 真的嗎???? 讓我們改一下程式碼如下: scanf("%d %d %d", &(tmp.c), &(tmp.b), &(tmp.a) ); printf("%d %d %d\n", tmp.a, tmp.b, tmp.c); 簡單來說,只是把讀取順序反過來,然後一樣輸入 1 2 3,結果答案是 3 0 0 而不是 3 2 1。到底發生了什麼事情??? 首先,當我們用 scanf 進行讀取的時候,是以 int 的方式讀入,也就是說總共讀入了 4 個 byte,所以第一段程式碼可以用下面的那張圖來表示: ----------------------- byte -------------------- +--------+-------+--------+ -------------------- |---a-----|---b---|---c...