C語言數(shù)據(jù)(整數(shù)、浮點(diǎn)數(shù))在內(nèi)存中的存儲
本篇主要討論:整數(shù)、浮點(diǎn)數(shù)在內(nèi)存中是怎么保存的!
數(shù)據(jù)類型詳細(xì)介紹
在前面C語言基礎(chǔ)概覽中,已經(jīng)提到過了基本的C語言內(nèi)置類型,但C語言的數(shù)據(jù)類型有無數(shù)種~ 但是可以把這些類型分為幾個大類:
類型的歸類:
- 存整數(shù)的
char,short,int,long,long long及所配套的unsigned,int*,int[]… - 2.存浮點(diǎn)數(shù)的
float,double,float[]… - 結(jié)構(gòu)體(結(jié)構(gòu)體在內(nèi)存中的存儲后面在進(jìn)行討論~)
整數(shù)在內(nèi)存種的存儲:
1.字節(jié)序
2.補(bǔ)碼
內(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,其實(shí)在Intel的CPU中表示中斷指令,VS的debug模式下,會把局部變量的后邊填充上0xcc,填充的目的是及時發(fā)現(xiàn)下標(biāo)越界
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; }
指針之間的強(qiáng)制類型轉(zhuǎn)換,不會影響指針內(nèi)部存儲的地址值,只影響后序的解引用操作~
網(wǎng)絡(luò)傳輸?shù)淖止?jié)序固定使用大端~
補(bǔ)碼
整形在內(nèi)存中的存儲:原碼、反碼、補(bǔ)碼
原碼:在正數(shù)的二進(jìn)制基礎(chǔ)上,把符號位設(shè)為1
反碼:符號位不變,其他位取反~
補(bǔ)碼:反碼+1,即可得到補(bǔ)碼
正數(shù)的原碼、反碼和補(bǔ)碼都相同
舉例:
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ù),高位直接"截?cái)?
2.把短的數(shù)據(jù)轉(zhuǎn)為成長的數(shù)據(jù),高位要補(bǔ)符號位
浮點(diǎn)型在內(nèi)存中的存儲
小數(shù)在計(jì)算機(jī)中的計(jì)算要比整數(shù)復(fù)雜很多~
浮點(diǎn)數(shù)儲存規(guī)則:
IEEE754規(guī)定:
對于32位的浮點(diǎn)數(shù):
最高的一位是符號位s,接著的8位是指數(shù)E,剩下的23位為有效數(shù)字M
對于64位的浮點(diǎn)數(shù):
最高的一位是符號位S,接著的11位是指數(shù)E,剩下的52位為有效數(shù)組M
一個浮點(diǎn)數(shù)在計(jì)算機(jī)里是運(yùn)用"科學(xué)計(jì)數(shù)法"的方式來表示的~用2的多少次方來表示
2^E (2的E次方)
E越大,能表示的數(shù)據(jù)范圍就越大
M越大,能表示的數(shù)據(jù)的精度就越高
因此優(yōu)先考慮使用double
內(nèi)存
一定要把內(nèi)存理解透徹~~指針基礎(chǔ)篇里有寫內(nèi)存,可以去看看~
總結(jié)
到此這篇關(guān)于C語言數(shù)據(jù)在內(nèi)存中的存儲的文章就介紹到這了,更多相關(guān)C語言數(shù)據(jù)存儲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言中g(shù)etchar函數(shù)詳解看這一篇就夠了(函數(shù)功能、使用、返回值)
getchar讀取字符的函數(shù),今天通過本文給大家介紹C語言中g(shù)etchar函數(shù)簡介用法示例詳解,感興趣的朋友跟隨小編一起看看吧2023-02-02C++實(shí)現(xiàn)二叉樹非遞歸遍歷方法實(shí)例總結(jié)
這篇文章主要介紹了C++實(shí)現(xiàn)二叉樹非遞歸遍歷方法實(shí)例總結(jié),是算法設(shè)計(jì)中比較經(jīng)典的一個遍歷算法,需要的朋友可以參考下2014-08-08推薦幾款C/C++的編譯器、編譯環(huán)境(非常全面的比較)
這篇文章主要介紹了C/C++編譯器的一些易混淆概念,這里腳本之家小編特為大家分享一下,需要的朋友可以參考下2021-06-06C語言鏈表實(shí)現(xiàn)歌手評分系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言鏈表實(shí)現(xiàn)歌手評分系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-03-03C++ OpenCV實(shí)現(xiàn)圖像去水印功能
本文將介紹如何使用OpenCV C++ 進(jìn)行簡單圖像水印去除。我們在網(wǎng)上download圖片時,經(jīng)常因?yàn)榘鏅?quán)問題有水印。本案例通過編寫算法進(jìn)行簡單水印去除。需要的可以參考一下2022-01-01C語言之關(guān)于二維數(shù)組在函數(shù)中的調(diào)用問題
這篇文章主要介紹了C語言之關(guān)于二維數(shù)組在函數(shù)中的調(diào)用問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07