A. c語言float是什麼意思及用法
C語言中float浮點型數據類型,FLOAT數據類型用於存儲單精度浮點數或雙精度浮點數。
浮點數使用 IEEE(電氣和電子工程師協會)格式。浮點類型的單精度值具有 4 個位元組,包括一個符號位、一個
8 位 excess-127 二進制指數和一個 23 位尾數。
尾數表示一個介於 1.0 和 2.0 之間的數。由於尾數的高順序位始終為 1,因此它不是以數字形式存儲的。此表示形式為 float 類型提供了一個大約在 -3.4E+38 和 3.4E+38 之間的范圍。
(1)c編程浮點類型視頻擴展閱讀
float造成的影響:
1、對其兄弟元素(浮動)的影響
當一個浮動元素在浮動過程中碰到同一個方向的浮動元素時,它會緊跟在它們後面,可以用這樣一個形象的比喻來描述:在一個購票中心裡,某人從一條購票隊列跑到旁邊的一條購票隊列中排隊,那自然先跑過去的會先佔據前面的位置。
2、float對自身元素的影響
float對象將被視作塊對象(block-level),即display屬性等於block。
3、float對子元素的影響
我們知道當一個元素浮動時,在沒有清楚浮動的情況下,它無法撐開其父元素,但它可以讓自己的浮動子元素撐開它自身,並且在沒有定義具體寬度情況下,使自身的寬度從100%變為自適應(浮動元素display:block)。其高度和寬度均為浮動元素高度和非浮動元素高度之間的最大值。
B. C語言:誰能給我解釋一下浮點型,這種數據類型啊
浮點型分為float 和double兩種類型,float在內存中佔4個位元組(32位),double在內存中佔8個位元組(64)位,float 提供7位有效數字,double提供15位有效數字,實際上在編程的過程中如果需要用浮點型時建議使用double 型 因為編譯器處理float和double型數據的效率差不多,沒多大差異,而且double型又能夠表達的比較精確!
Int char long float double DWORD
4 1 4 4 8 4 //32位計算機
2 1 4 4 8 //16位計算機
C. C語言中float是什麼意思
C語言中float浮點型數據類型,FLOAT 數據類型用於存儲單精度浮點數或雙精度浮點數。浮點數使用 IEEE(電氣和電子工程師協會)格式。浮點類型的單精度值具有 4 個位元組,包括一個符號位、一個
8 位 excess-127 二進制指數和一個 23 位尾數。
尾數表示一個介於 1.0 和 2.0 之間的數。由於尾數的高順序位始終為
1,因此它不是以數字形式存儲的。此表示形式為 float 類型提供了一個大約在 -3.4E+38 和 3.4E+38 之間的范圍。
定義輸入輸出舉例如下:
float和double的區別:
1.指數和尾數
由於指數是以無符號形式存儲的,因此指數的偏差為其可能值的一半。對於 float 類型,偏差為 127;對於 double 類型,偏差為 1023。可以通過將指數值減去偏差值來計算實際指數值。
2.浮點類型
如果存儲比精度更重要,請考慮對浮點變數使用 float 類型。相反,如果精度是最重要的條件,則使用 double 類型。浮點變數可以提升為更大基數的類型(從 float 類型到 double 類型)。當您對浮點變數執行算術時,通常會出現提升。此算術始終以與具有最高精度的變數一樣高的精度執行。
D. C語言編程float型數據轉化為2進制數輸出
你先看看這個,如果看不懂,就追問。
《C語言中,float在內存中的儲存方式》:
浮點型變數在計算機內存中佔用4位元組(Byte),即32-bit。
遵循IEEE-754格式標准。 一個浮點數由2部分組成:底數m 和 指數e。
±mantissa × 2exponent (注意,公式中的mantissa 和 exponent使用二進製表示)
底數部分 使用2進制數來表示此浮點數的實際值。
指數部分 佔用8-bit的二進制數,可表示數值范圍為0-255。
但是指數應可 正可負,所以IEEE規定,此處算出的次方須減去127才是真正的指數。所以float的指數可從 -126到128. 底數部分實際是佔用24-bit的一個值,由於其最高位始終為 1 ,所以最高位省去不存儲,在存儲中只有23-bit。
到目前為止, 底數部分 23位 加上指數部分 8位 使用了31位。那麼前面說過,float是佔用4個位元組即32-bit,那麼還有一位是幹嘛用的呢? 還有一位,其實就是4位元組中的最高位,用來指示浮點數的正負,當最高位是1時,為負數,最高位是0時,為正數。
浮點數據就是按下表的格式存儲在4個位元組中:
Address+0 Address+1 Address+2 Address+3 Contents
SEEE EEEE EMMM MMMM MMMM MMMM MMMM MMMM
S: 表示浮點數正負,1為負數,0為正數
E: 指數加上127後的值的二進制數
M: 24-bit的底數(只存儲23-bit)
主意:這里有個特例,浮點數 為0時,指數和底數都為0,但此前的公式不成立。因為2的0次方為1,所以,0是個特例。當然,這個特例也不用認為去干擾,編譯器會自動去識別。 通過上面的格式,我們下面舉例看下-12.5在計算機中存儲的具體數據:
Address+0 Address+1 Address+2 Address+3 Contents
0xC1 0x48 0x00 0x00
接下來我們驗證下上面的數據表示的到底是不是-12.5,從而也看下它的轉換過程。 由於浮點數不是以直接格式存儲,他有幾部分組成,所以要轉換浮點數,首先要把各部分的值分離出來。
Address+0 Address+1 Address+2 Address+3
格式SEEEEEEE EMMMMMMM MMMMMMMM MMMMMMMM
二進制 11000001 01001000 00000000 00000000
16進制 C1 48 00 00
可見:
S: 為1,是個負數。
E:為 10000010 轉為10進制為130,130-127=3,即實際指數部分為3.
M:為 10010000000000000000000。
這里,在底數左邊省略存儲了一個1,
使用 實際底數表示為1.10010000000000000000000 到此,我們吧三個部分的值都拎出來了,現在,我們通過指數部分E的值來調整底數部分M的值。調整方法為:如果指數E為負數,底數的小數點向左移,如果指數E為正數,底數的小數點向右移。小數點移動的位數由指數E的絕對值決定。 這里,E為正3,使用向右移3為即得: 1100.10000000000000000000 至次,這個結果就是12.5的二進制浮點數,將他換算成10進制數就看到12.5了,如何轉換,看下面: 小數點左邊的1100 表示為 (1 × 23) + (1 × 22) + (0 × 21) + (0 × 20), 其結果為 12 。 小數點右邊的 .100… 表示為 (1 × 2-1) + (0 × 2-2) + (0 × 2-3) + ... ,其結果為.5 。 以上二值的和為12.5, 由於S 為1,使用為負數,即-12.5 。所以,16進制 0XC1480000 是浮點數 -12.5 。
上面是如何將計算機存儲中的二進制數如何轉換成實際浮點數,下面看下如何將一浮點數裝換成計算機存儲格式中的二進制數。 舉例將17.625換算成 float型。
首先,將17.625換算成二進制位:
10001.101 ( 0.625 = 0.5+0.125, 0.5 即 1/2, 0.125即 1/8 如果不會將小數部分轉換成二進制,請參考其他書籍。)
再將 10001.101 向右移,直到小數點前只剩一位 成了 1.0001101 x 2的4次方(因為右移了4位)。此時 我們的底數M和指數E就出來了: 底數部分M,因為小數點前必為1,所以IEEE規定只記錄小數點後的就好,所以此處底數為 0001101 。 指數部分E,實際為4,但須加上127,固為131,即二進制數 10000011 符號部分S,由於是正數,所以S為0. 綜上所述,17.625的 float 存儲格式就是: 0 10000011 00011010000000000000000 轉換成16進制:0x41 8D 00 00 所以,一看,還是佔用了4個位元組。
下面,我做了個有趣的實驗,就是由用戶輸入一個浮點數,程序將這個浮點數在計算機中存儲的二進制直接輸出,來看看我們上面所將的那些是否正確。 有興趣同學可以到VC6.0中去試試~!
#include<iostream.h>
#define uchar unsigned char
void binary_print(uchar c)
{
for(int i = 0; i < 8; ++i)
{
if((c << i) & 0x80)
cout << '1'; else cout << '0';
}
cout << ' ';
}
void main()
{
float a;
uchar c_save[4];
uchar i;
void *f;
f = &a;
cout<<"請輸入一個浮點數:";
cin>>a;
cout<<endl;
for(i=0;i<4;i++)
{
c_save[i] = *((uchar*)f+i);
}
cout<<"此浮點數在計算機內存中儲存格式如下:"<<endl;
for(i=4;i!=0;i--)
binary_print(c_save[i-1]);
cout<<endl;
}