根據 IEEE 754 二進位浮點數算術標準,請問下列 C 語言程式碼執行後輸出為何?
int main(){
float A = 100;
float B = -125.53125;
printf("%08X\n", *(unsigned int *) &A);
printf("%08X\n", *(unsigned int *) &B);
}
解答:
42C80000
C2FB1000
我的想法:
在*(unsigned int *) &A這部分
是強制轉換成一個無號整數型態的指標變數 並指向A的位址
而最前方的*則代表會顯示A位址的內容(值)
也就是最後會以無號整數的型態顯示出A的內容
======================================================
以上是我的想法若有錯誤還請糾正
解答部分是將100用浮點數表示法轉換成
01000010110010000000000000000000
也就是浮點數的32位元
再將這32位元用16進位表示法顯示出來成為42C80000
但今天我自己在程式中加入以下敘述
float C = 100;
printf("%08X", (unsigned int) C);
則只顯示成00000064
為何電腦不會先轉換成浮點數表示法再用16進位去做轉換 而是直接將100轉成16進位?
還請知道的大大提點 感謝