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ù)種~ 但是可以把這些類型分為幾個(gè)大類:
類型的歸類:
- 存整數(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,填充的目的是及時(shí)發(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
一個(gè)浮點(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++利用jsoncpp庫實(shí)現(xiàn)寫入和讀取json文件
JsonCpp 是一個(gè)C++庫,允許操作 JSON 值,包括序列化和反序列化到字符串和從字符串反序列化。本文主要介紹了如何利用jsoncpp庫實(shí)現(xiàn)寫入和讀取json文件,感興趣的可以了解一下2023-04-04C語言實(shí)現(xiàn)學(xué)生學(xué)籍管理系統(tǒng)程序設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)學(xué)生學(xué)籍管理系統(tǒng)程序設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07sqlserver,sqlite,access數(shù)據(jù)庫鏈接字符串整理
本節(jié)主要整理sqlserver,sqlite,access數(shù)據(jù)庫鏈接字符串,有需要的朋友可以參考下2014-07-07C++中智能指針unique_ptr的實(shí)現(xiàn)詳解
智能指針本質(zhì)上并不神秘,其實(shí)就是?RAII?資源管理功能的自然展現(xiàn)而已,這篇文章主要為大家詳細(xì)介紹了如何實(shí)現(xiàn)?C++中智能指針的?unique_ptr,需要的可以了解下2024-01-01關(guān)于C++使用std::chrono獲取當(dāng)前秒級/毫秒級/微秒級/納秒級時(shí)間戳問題
這篇文章主要介紹了C++使用std::chrono獲取當(dāng)前秒級/毫秒級/微秒級/納秒級時(shí)間戳,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07C++ OpenCV實(shí)現(xiàn)抖音"藍(lán)線挑戰(zhàn)"特效
這篇文章主要介紹了如何使用OpenCV C++ 實(shí)現(xiàn)抖音上的特效“藍(lán)線挑戰(zhàn)”。文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)OpenCV有一定的幫助,需要的可以參考一下2022-01-01