您好,登錄后才能下訂單哦!
這篇文章主要介紹“C語言數(shù)據(jù)在內(nèi)存中是怎樣存儲的”,在日常操作中,相信很多人在C語言數(shù)據(jù)在內(nèi)存中是怎樣存儲的問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C語言數(shù)據(jù)在內(nèi)存中是怎樣存儲的”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
在前面C語言基礎(chǔ)概覽中,已經(jīng)提到過了基本的C語言內(nèi)置類型,但C語言的數(shù)據(jù)類型有無數(shù)種~ 但是可以把這些類型分為幾個大類:
類型的歸類:
存整數(shù)的
char,short,int,long,long long及所配套的unsigned,int*,int[]…
2.存浮點數(shù)的
float,double,float[]…
結(jié)構(gòu)體(結(jié)構(gòu)體在內(nèi)存中的存儲后面在進行討論~)
1.字節(jié)序
2.補碼
內(nèi)存窗口
調(diào)試模式下的內(nèi)存窗口,若不是調(diào)試狀態(tài),是打不開內(nèi)存窗口的,正常情況下,不調(diào)試,是沒有內(nèi)存窗口的
char str[]="abc";
這里內(nèi)存數(shù)據(jù)只截了部分圖,方便清晰觀察
內(nèi)存數(shù)據(jù)中有很多的"cc cc cc",就是0xcc,其實在Intel的CPU中表示中斷指令,VS的debug模式下,會把局部變量的后邊填充上0xcc,填充的目的是及時發(fā)現(xiàn)下標越界
int num = 0x11223344;
此處就涉及到字節(jié)序
字節(jié)序
字節(jié)序是以字節(jié)為單位
字節(jié)序分為大端字節(jié)序(大端序)和小端字節(jié)序(小端序)
大端字節(jié)序:就是把地位放在高地址上
小端字節(jié)序:就是把低位(小)放在低地址(小)上 (小小小)
總的來說,小端序的應(yīng)用更廣泛。字節(jié)序是和CPU相關(guān)的屬性,Intel的CPU主要都是小端序~
上述例子:0x11223344 內(nèi)存數(shù)據(jù)若是11223344,則為大端序,44332211則為小端序。
程序判斷大端序or小端序?
int isBidEnd() { int num = 0x11223344; int* p = # char* p2 = (char*)p; if (*p2 == 0x11) { return 1; } else { return 0; } } int main() { int ret = isBidEnd(); if (ret == 1) { printf("是大端序\n"); } else { printf("是小端序\n"); } system("pause"); return 0; }
指針之間的強制類型轉(zhuǎn)換,不會影響指針內(nèi)部存儲的地址值,只影響后序的解引用操作~
網(wǎng)絡(luò)傳輸?shù)淖止?jié)序固定使用大端~
補碼
整形在內(nèi)存中的存儲:原碼、反碼、補碼
原碼:在正數(shù)的二進制基礎(chǔ)上,把符號位設(shè)為1
反碼:符號位不變,其他位取反~
補碼:反碼+1,即可得到補碼
正數(shù)的原碼、反碼和補碼都相同
舉例:
int main() { char a = -1; signed char b = -1;//char 和signed char 沒區(qū)別 unsigned char c = -1; printf("a=%d\nb=%d\nc=%d\n", a, b, c); system("pause"); return 0; }
類型轉(zhuǎn)換的規(guī)則
1.把長的數(shù)據(jù)轉(zhuǎn)換成短的數(shù)據(jù),高位直接"截斷"
2.把短的數(shù)據(jù)轉(zhuǎn)為成長的數(shù)據(jù),高位要補符號位
小數(shù)在計算機中的計算要比整數(shù)復(fù)雜很多~
浮點數(shù)儲存規(guī)則:
IEEE754規(guī)定:
對于32位的浮點數(shù):
最高的一位是符號位s,接著的8位是指數(shù)E,剩下的23位為有效數(shù)字M
對于64位的浮點數(shù):
最高的一位是符號位S,接著的11位是指數(shù)E,剩下的52位為有效數(shù)組M
一個浮點數(shù)在計算機里是運用"科學(xué)計數(shù)法"的方式來表示的~用2的多少次方來表示
2^E (2的E次方)
E越大,能表示的數(shù)據(jù)范圍就越大
M越大,能表示的數(shù)據(jù)的精度就越高
因此優(yōu)先考慮使用double
到此,關(guān)于“C語言數(shù)據(jù)在內(nèi)存中是怎樣存儲的”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。