整型數(shù)據(jù)在內(nèi)存中存儲方式的講解-創(chuàng)新互聯(lián)

(以下討論,針對32位的計算機系統(tǒng)。。)

成都創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:成都網(wǎng)站建設、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的玉田網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!

問:int型數(shù)據(jù)占幾個字節(jié)?答:4字節(jié)。地球上這個群體的人都知道。

再問:這4個字節(jié),即32個二進制位,又是何存儲?這就進入計算機的“底層”了。這個事情,學習程序設計的童鞋,可以懂。

存儲的方式,和我們拍腦袋想得不太一樣,概括一下,就是低位在前,高位在后。

本文直觀一些,看懂以下程序中數(shù)據(jù)的存儲,也便知道這個安排。

整型數(shù)據(jù)在內(nèi)存中存儲方式的講解

(源程序,及在watch窗口中用多種方式看x.c的方法,見文后附件。)

在程序中,由于聯(lián)合體存儲的特點,變量x占4個字節(jié)。我們可以從3個角度觀察這4個字節(jié):(1) 整體看,是一個int型數(shù)據(jù);(2) 分成2部分看,是兩個短整型數(shù)據(jù);(3) 分成4部分看,是4個單字節(jié)的數(shù)據(jù)。

但無論怎么看,就是這4個字節(jié)。無論用哪種形式操作數(shù)據(jù),使用的也就是這4個字節(jié)。聯(lián)合體為我們提供了從不同的角度使用這4個字節(jié)的方式。

x.c[0]到x.c[3]的值分別為65\66\67\68,這好理解。

x.si[0]占的2字節(jié),與x.c[0]和x.c[1]相同。驗證一下:16961=66×256+65(66是'B'的ACSII值,65是'A'的ASCII值,是字符的存儲形式)。注意,這里體現(xiàn)存儲數(shù)據(jù)時低位在前,高位在后,低位是65,高位是66。正如十進制數(shù)98中,高位是9,低位是8,所以98=9×10+8一樣。因為是高位,所以乘以位權10,表示9這個符號代表的其實是90。66×256,是因為存儲66(‘B')的那一個字節(jié)的位置,比存儲65(‘A')的那一個字節(jié)的位置高8位,所以乘以2的8次方,即256。

概括講,存儲2字節(jié)的16961時,其低8位,是65,在前(x.c[0]),而其高8位,是66,在后(x.c[1])。低位在前,高位在后。

請自行驗證:17475=68×256+67,體現(xiàn)低位在前,高位在后。(x.si[0]占的2字節(jié),與x.c[2]和x.c[3]相同)

再請驗證:1145258561=17475×256×256+16961,也體現(xiàn)低位在前,高位在后。(x.i占的4字節(jié),與x.si[0]和x.si[1]相同)

再請驗證:1145258561=68×256×256×256+67×256×256+66×256+65。同樣的道理。

換種寫法,是1145258561=(((68×256+67)×256+66)×256+65。

再看截圖,品味低位在前,高位在后。

這樣安排的道理,在以后的關于“計算機的原理”的有關專業(yè)課中會接觸到。

附1:本文源程序

#include <iostream>
using namespace std;
union un
{
  int i;
  short int si[2];
  char c[4];
};
int main()
{
  union un x;
  x.c[0]='A';
  x.c[1]='B';
  x.c[2]='C';
  x.c[3]='D';
  cout<< x.c[0]<<","<<x.c[1]<<","<< x.c[2]<<","<< x.c[3]<<endl;
  cout<<x.si[0]<<","<< x.si[1]<<endl;
  cout<<x.i<<endl;
  return 0;
}

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站muchs.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

本文標題:整型數(shù)據(jù)在內(nèi)存中存儲方式的講解-創(chuàng)新互聯(lián)
URL地址:http://muchs.cn/article32/cshspc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、品牌網(wǎng)站建設、網(wǎng)頁設計公司網(wǎng)站策劃、云服務器、網(wǎng)站排名

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)