詳解C語言中數(shù)據(jù)的存儲(chǔ)
一、類型歸類
對于基本的c語言數(shù)據(jù)類型的基本歸類
1、整形家族
char (內(nèi)存存儲(chǔ)的為ascall碼值,存儲(chǔ)為整數(shù))
unsigned char// unsigned為無符號(hào)關(guān)鍵字
signe char//
short
unsigned short (int)// (int )表示int可以省略不寫
signed short (int)
int
unsigned int
signed int
long
unsigned long (int)
signed long (int)
2、浮點(diǎn)型家族
float
double
3、指針類型
int* ptr; char* pa; float* pf; void* pv;
4、空類型
void 表示空類型(無類型)
通常應(yīng)用于函數(shù)的返回類型,返回參數(shù),指針類型
二、類型的意義
1.占據(jù)的內(nèi)存大小
2.作為數(shù)據(jù)時(shí)所操作的大?。礊閿?shù)據(jù)看待類型的視角)
三、數(shù)據(jù)在類型中存儲(chǔ)(以整形和浮點(diǎn)型為例子)
1. 關(guān)于 存儲(chǔ)的基本概念
計(jì)算機(jī)的(整形)有符號(hào)數(shù),有三種表示方法,原碼,反碼,補(bǔ)碼
三種表示方法 均存在 符號(hào)位 和 數(shù)值位 兩部分,符號(hào)位的‘0'表正,‘1'表示負(fù),數(shù)值位表示方法有差異(對于無符號(hào)數(shù):原,反,補(bǔ)表示相同)
原碼:直接將數(shù)字按照正負(fù),用二進(jìn)制方法翻譯表示;
反碼:將原碼的符號(hào)位不變,其他位按位取反;
補(bǔ)碼:反碼+1;
對于正數(shù)而言,原,反,補(bǔ)相同:
int a=20; // 00000000 00000000 00000000 00010100 原碼 // 00000000 00000000 00000000 00010100 反碼 // 00000000 00000000 00000000 00010100 補(bǔ)碼
對于負(fù)數(shù)而言
int a=-1; // 10000000 00000000 00000000 00001010 原碼 // 11111111 11111111 11111111 11110101 反碼 // 11111111 11111111 11111111 11110110 補(bǔ)碼
對于整形數(shù)據(jù)而言再內(nèi)存存儲(chǔ)的是補(bǔ)碼
2.存儲(chǔ)模式
1.大端模式(大端字節(jié)序模式):較高的有效字節(jié)存儲(chǔ)在較低的存儲(chǔ)器地址,較低的有效字節(jié)存儲(chǔ)在較高的存儲(chǔ)器地址。
2.小端模式(小端字節(jié)序模式):較低的有效字節(jié)存儲(chǔ)在較低的存儲(chǔ)器地址,較高的有效字節(jié)存儲(chǔ)在較高的存儲(chǔ)器地址。
地址的視圖
低-------------------------------->--------高
關(guān)于設(shè)計(jì)判斷當(dāng)前機(jī)器的字節(jié)序
int check_sys(void)
{
int a=1;
char* p=(char*)&a;//訪問第一個(gè)字節(jié)序看是 01.....0 還是 0...01
return *p;
}
int main()
{
int ret=check_sys();
if(ret==1)
printf("小端");
else
printf("大端");
}
在這里強(qiáng)制轉(zhuǎn)化成(char*)利用他只訪問一個(gè)字節(jié)的視角進(jìn)行觀測
指針類型的意義
1.指針類型決定了指針類型解引用操作符能訪問幾個(gè)字節(jié)
2.指針+類型決定了指針+1跳過幾個(gè)字節(jié)
四.應(yīng)用
應(yīng)用前應(yīng)掌握的基本概念 整形提升
1.
char a=-1;
// -1作為整形數(shù)在內(nèi)存中以補(bǔ)碼形式存儲(chǔ)
// 10000000 00000000 00000000 0000001-原碼
// 11111111 11111111 11111111 1111110 - 反碼
// 11111111 11111111 11111111 1111111 -補(bǔ)碼
// 當(dāng)被賦予a時(shí) a為char型只能存儲(chǔ)8個(gè)字節(jié) 就要發(fā)生 截?cái)?
// 即 a 存儲(chǔ)為 1111111
signed char b=-1;
// sigend為默認(rèn)關(guān)鍵字 聲明和聲明都默認(rèn)為有符號(hào)
// 同理 b 1111111
unsigned char c=-1;
// c 1111111將高位當(dāng)做數(shù)值位對待
printf("%d %d %d ",a,b,c);
// -1 -1 255
// 當(dāng)要打印為%d 應(yīng)當(dāng)發(fā)生整形提升
// 負(fù)數(shù)為有符號(hào)型 整形提升高位補(bǔ)1;
// 無符號(hào)型提升高位補(bǔ)0,將原高位看作數(shù)值位
// 將 計(jì)算過程的 補(bǔ)碼 轉(zhuǎn)換為原碼后即為所求結(jié)果
2.
char a=-128;
printf("%u\n",a);

char a=-128; //10000000 00000000 00000000 10000000 //11111111 11111111 11111111 01111111 //11111111 11111111 11111111 10000000 // 截?cái)?0000000 // char a 有符號(hào) 按符號(hào)位提升 //整形提升 11111111 11111111 11111111 10000000 作為 無符號(hào)數(shù) 原反補(bǔ)相同 //11111111 11111111 11111111 10000000-轉(zhuǎn)換為對應(yīng)的十進(jìn)制數(shù)
對于char范圍的討論
有符號(hào)的(以下均為補(bǔ)碼)


有符號(hào)char范圍 -128 --127
例題
char a[1000];
int i;
for(i=0;i<1000;i++)
{
a[i]=-1-i;
}
printf("%d",strlen(a));

對于 a[i]的計(jì)算結(jié)果 從 -1......-128..127....1 0
所以所得結(jié)果為 128+127=255
無符號(hào)(同補(bǔ)碼)

最高位視為數(shù)值位則 范圍為 0 ---255
例題
unsigned char i=0;
for(i=0;i<255;i++)
{
printf(" hello\n");
}
思路同上
程序陷入死循環(huán)
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
判斷一個(gè)數(shù)是不是素?cái)?shù)的方法
判斷一個(gè)數(shù)是不是素?cái)?shù)的方法,需要的朋友可以參考一下2013-03-03
C語言數(shù)據(jù)結(jié)構(gòu)之線索二叉樹及其遍歷
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)之線索二叉樹及其遍歷的相關(guān)資料,為了加快查找節(jié)點(diǎn)的前驅(qū)和后繼。對二叉樹的線索化就是對二叉樹進(jìn)行一次遍歷,在遍歷的過程中檢測節(jié)點(diǎn)的左右指針是否為空,如果是空,則將他們改為指向前驅(qū)和后繼節(jié)點(diǎn)的線索,需要的朋友可以參考下2017-08-08
淺談CMake配置OpenCV 時(shí)靜態(tài)鏈接與動(dòng)態(tài)鏈接的選擇
下面小編就為大家?guī)硪黄獪\談CMake配置OpenCV 時(shí)靜態(tài)鏈接與動(dòng)態(tài)鏈接的選擇。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01
C語言中g(shù)etopt()函數(shù)和select()函數(shù)的使用方法
這篇文章主要介紹了C語言中g(shù)etopt()函數(shù)和select()函數(shù)的使用方法,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-09-09

