float在內(nèi)存中的存儲形式:
成都創(chuàng)新互聯(lián)專注于嘉禾企業(yè)網(wǎng)站建設(shè),響應(yīng)式網(wǎng)站建設(shè),商城網(wǎng)站制作。嘉禾網(wǎng)站建設(shè)公司,為嘉禾等地區(qū)提供建站服務(wù)。全流程定制設(shè)計(jì),專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,成都創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)先看下面一道例題:
float *p = (float *)#
printf( "num=%d\n", num);
printf( "*p=%d\n", *p);
*p = 5.0;
printf( "num=%d\n", num);
printf( "*p=%f\n", *p);
這是因?yàn)閒loat在計(jì)算機(jī)中的存儲形式與int存儲形式不同造成的:
對于float類型:
例如:5.0(101)在內(nèi)存中的存儲形式是
5.0=(-1)^0*(1.01)*2^2
0 10000010 01000000000000000000000
有沒有對指數(shù)位E感到奇怪呢?因?yàn)镋占有8個bit位,取值范圍是0-255,取不到負(fù)數(shù),所以我們給E加上一個127再存到指數(shù)位中。這樣就可以取到
負(fù)數(shù)。當(dāng)我們讀取這個時給E減去127就行了。
當(dāng)E為全0時,表示一個接近0的數(shù),因?yàn)镋為全0時,M將不再加1,m為0.xxxxxxx...的形式,浮點(diǎn)數(shù)的指數(shù)為1-127,是一個非長小的數(shù)。
當(dāng)E為全1時,如果M為全0,則表示一個正負(fù)無窮大的數(shù)。
現(xiàn)在對于上面的例題清楚了吧,同一個數(shù)分別以float和int的形式去看,看到的結(jié)果是不同的。
對于double形式,是一樣的,只不過double是8個字節(jié),64個bit位,所以double的指數(shù)位是11位(要加一個1023),有效位是52位。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。