欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言數(shù)據(jù)(整數(shù)、浮點(diǎn)數(shù))在內(nèi)存中的存儲

 更新時間:2021年06月03日 14:29:54   作者:一朵花花  
之前對c語言數(shù)據(jù)存儲一直不太明白,最近仔細(xì)研究了一番,所以下面這篇文章主要給大家介紹了關(guān)于C語言數(shù)據(jù)(整數(shù)、浮點(diǎn)數(shù))在內(nèi)存中存儲的相關(guān)資料,需要的朋友可以參考下

本篇主要討論:整數(shù)、浮點(diǎn)數(shù)在內(nèi)存中是怎么保存的!

數(shù)據(jù)類型詳細(xì)介紹

在前面C語言基礎(chǔ)概覽中,已經(jīng)提到過了基本的C語言內(nèi)置類型,但C語言的數(shù)據(jù)類型有無數(shù)種~ 但是可以把這些類型分為幾個大類:

類型的歸類:

  1. 存整數(shù)的
    char,short,int,long,long long及所配套的unsigned,int*,int[]…
  2. 2.存浮點(diǎn)數(shù)的
    float,double,float[]…
  3. 結(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)文章

最新評論