c語言浮點數表示規(guī)則 學習c語言的時候指針應該怎么理解?
學習c語言的時候指針應該怎么理解?簡而言之,指針是表示地址的無符號整數。所以僅僅理解指針是不夠的。您還需要知道指針指向的數據空間是如何排列的。這可能涉及到一些與特定CPU/OS相關的知識。如果我們能用
學習c語言的時候指針應該怎么理解?
簡而言之,指針是表示地址的無符號整數。
所以僅僅理解指針是不夠的。您還需要知道指針指向的數據空間是如何排列的。這可能涉及到一些與特定CPU/OS相關的知識。如果我們能用計算機體系結構的知識來理解它,它會更深刻、更準確。
例如:
如何存儲float/double/long double?
如何在數據空間中組織陣列?
字符串是如何存儲的?
如何存儲結構和聯合體?
位域組織
具體CPU相關部分如下:
整數的存儲將涉及CPU大小的指定
浮點數的存儲直接關系到FPU的設計
此外,還有一些擴展知識,涉及內存的分配和釋放:如何在程序中分配內存?(malloc/free)
什么是堆和堆棧?
總而言之:指針是地址和整數。但要充分利用它,我們需要了解計算機存儲空間的分配。困難在這里,突破在這里。
什么是c語言中合法的浮點數?
什么樣的浮點數是合法的?符合IEEE-754的浮點數是合法的。目前,大多數高級語言(包括c語言)都按照IEEE-754標準規(guī)定了浮點數的存儲格式。IEEE-754標準規(guī)定了三種浮點數格式:單精度、雙精度和擴展精度。這次只討論前兩個問題。浮點型的表示方法是:浮點數的尾數用原碼或補碼表示,順序碼用補碼或移位碼表示。單精度:n為32位,其中s為1位,e為8位,M為23位。雙精度:n共64位,其中s占1位,e占11位,M占52位。