C語言謎題記錄

來源:互聯網
上載者:User

看完了C語言謎題,收穫頗多,進一步理解了C語言,從其中列出的每個例子中都能夠學到很多之前被忽視的知識點。

這裡記錄幾個不錯的case.

下面的程式會輸出什嗎?

#include <stdio.h>int main(){    float a = 12.5;    printf("%d\n", a);    printf("%d\n", (int)a);    printf("%d\n", *(int *)&a);    return 0;}

參考答案:

該項程式輸出如下所示,

0

12

1095237632

原因是:浮點數是4個位元組,12.5f 轉成二進位是:01000001010010000000000000000000,十六進位是:0×41480000,十進位是:1095237632。所以,第二和第三個輸出相信大家也知道是為什麼了。而對於第一個,為什麼會輸出0,我們需要瞭解一下float和double的記憶體布局,如下:

float: 1位符號位(s)、8位指數(e),23位尾數(m,共32位)

   double: 1位符號位(s)、11位指數(e),52位尾數(m,共64位)

然後,我們還需要瞭解一下printf由於類型不符,所以,會把float直接轉成double,注意,12.5的float和double的記憶體二進位完全不一樣。別忘了在x86晶片下使用是的反位元組序,高位位元組和低位字位要反過來。所以:

float版:0×41480000 (在記憶體中是:00 00 48 41)

   double版:0×4029000000000000 (在記憶體中是:00 00 00 00 00 00 29 40)

而我們的%d要求是一個4位元組的int,對於double的記憶體布局,我們可以看到前四個位元組是00,所以輸出自然是0了。

這個樣本向我們說明printf並不是型別安全的,這就是為什麼C++要引如cout的原因了。

ATTENTION:

1,"hello"[2] == 2["hello"] = 'l'

2,C/C++中,以0開頭的數字都是八進位的。

3,sizeof不是一個函數,是一個操作符,其求i++的類型的size,這是一件可以在程式運行前(編譯時間)完全的事情,所以,sizeof(i++)直接就被4給取代了,在運行時也就不會有了i++這個運算式。

4,switch-case體中的變數初始化語句不會被執行。

5,printf傳回值是輸出的字元個數。

6,stdout和stderr是不是同裝置描述符。stdout是塊裝置,stderr則不是。對於塊裝置,只有當下面幾種情況下才會被輸入,1)遇到斷行符號,2)緩衝區滿,3)flush被調用。而stderr則不會。

本文出自 “About:Blank H4cking” 部落格,請務必保留此出處http://pnig0s1992.blog.51cto.com/393390/814005

查看本欄目更多精彩內容:http://www.bianceng.cnhttp://www.bianceng.cn/Programming/C/

相關文章

E-Commerce Solutions

Leverage the same tools powering the Alibaba Ecosystem

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。