欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

c++整數(shù)在內(nèi)存中的存儲(chǔ)方法是什么

今天小編給大家分享一下c++整數(shù)在內(nèi)存中的存儲(chǔ)方法是什么的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來(lái)了解一下吧。

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比源城網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式源城網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋源城地區(qū)。費(fèi)用合理售后完善,十載實(shí)體公司更值得信賴。

存放格式
對(duì)整數(shù)來(lái)說(shuō),數(shù)據(jù)存放在內(nèi)存中其實(shí)存放的是補(bǔ)碼。原因是在計(jì)算機(jī)系統(tǒng)中,數(shù)值一律補(bǔ)碼來(lái)表示和存儲(chǔ),原因在于,使用補(bǔ)碼,可將符號(hào)位和數(shù)值域統(tǒng)一處理,同時(shí),加法減法也可以統(tǒng)一處理(cpu只有加法器),此外,補(bǔ)碼和原碼相互轉(zhuǎn)換,運(yùn)算過程完全相同,不需要額外的硬件電路。

大小端介紹
大段存儲(chǔ)模式:指數(shù)據(jù)的低權(quán)值位存放于內(nèi)存的高地址,高權(quán)值位存放于內(nèi)存的低地址。
小段存儲(chǔ)模式:指數(shù)據(jù)的高權(quán)值位存放于內(nèi)存的高地址,低權(quán)值位存放于內(nèi)存的低地址。

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
int Judge1()                   //法一:利用地址int強(qiáng)轉(zhuǎn)char判斷。
{
    int i = 1;
    return *(char *)&i;        //i共四個(gè)地址,取地址取最小的,再加個(gè)強(qiáng)轉(zhuǎn)解引用后只取地址最小空間里的值。
}
int Judge2()                   //法二:利用unio聯(lián)合體的特點(diǎn):所有成員共享空間。聯(lián)合體空間大小為成員所占空間的最大值,空間小的從低地址開始。
{
    union {
        int a;
        char i;
    }u1;
    u1.a = 1;
    return u1.i;
}
int main()
{
    int ret;
    ret = Judge2();
    if (1 == ret)
    {
        printf("小端存儲(chǔ)模式\n");
    }
    else if (0 == ret)
    {
        printf("大端存儲(chǔ)模式\n");
    }

    system("pause");
    return 0;
}

在內(nèi)存中進(jìn)行加減過程
題一:

char a = -1;                 //原碼 1000 0001   補(bǔ)碼 1111 1111
    signed char b = -1;          //原碼 1000 0001   補(bǔ)碼 1111 1111
    unsigned char c = -1;        //原碼 1000 0001   補(bǔ)碼 1111 1111
                                               //%d char轉(zhuǎn)int型發(fā)生×××提升,有符號(hào)數(shù)發(fā)生×××提升前面補(bǔ)符號(hào)位,無(wú)符號(hào)數(shù)補(bǔ)0                 
    printf("a=%d\n", a);         //提升后  a=1111 1111 1111 1111 1111 1111 1111 1111 (補(bǔ)碼) 輸出原碼:1000 0000 0000 0000 0000 0000 0000 0001 =-1 
    printf("b=%d\n", b);         //同上
    printf("c=%d\n", c);         //提升后  c=0000 0000 0000 0000 0000 0000 1111 1111 (補(bǔ)碼) 輸出原碼:0000 0000 0000 0000 0000 0000 1111 1111 =255

題二:

1>
char a = -128;               //原碼 1 1000 0000  符號(hào)位溢出后截?cái)?nbsp;變?yōu)?000 0000   補(bǔ)碼:1 1000 0000再次截?cái)?000 0000 
    printf("%u\n", a);           //×××提升:1111 1111 1111 1111 1111 1111 1000 0000 (補(bǔ)碼) 因?yàn)槭菬o(wú)符號(hào)×××輸出,所以輸出該二進(jìn)制對(duì)應(yīng)的十進(jìn)制數(shù)。

2>
char a = 128;                 //原碼:0 1000 0000  符號(hào)位溢出后截?cái)?nbsp;變?yōu)?000 0000   補(bǔ)碼:1 1000 0000再次截?cái)?000 0000 
    printf("%u\n", a);            //由此可看出答案同上

題三:

unsigned char i = 0;           //表示數(shù)值范圍:0~255
    for (i = 0; i <= 255; i++)     //一直在0~255之間,當(dāng)i=255再加1時(shí),發(fā)生截?cái)嗪缶陀肿優(yōu)?了  1111 1111+0000 0001=1 | 0000 0000 =0
    {
        printf("%d\n", i);         //所以一直循環(huán),(死循環(huán))重復(fù)打印0~255
        if (i <= 250)
        {
            Sleep(30);
        }
        else{
            Sleep(1000);
        }
    }

題四:

unsigned int i ;           //表示數(shù)值范圍:0~2^32-1
    for (i = 9; i >=0; i--)     //一直在0~2^32-1之間,當(dāng)i=0再減1時(shí),發(fā)生截?cái)嗪缶陀肿優(yōu)?了  0000 0000 .... 0000 + 1111 ...1111=1111....1111 =1... 1111 因?yàn)槭菬o(wú)符號(hào)數(shù),所以為2^32-1
    {
        printf("%d\n", i);         //所以一直循環(huán),(死循環(huán))打印9、8、7...0 后從2^32-1開始減
        if (i <= (pow(2,32)-10))
        {
            sleep(10);
        }
        else{
            sleep(1000);
        }
    }

題五:

char a[1000];                         //-128~127
    int i;
    for (i = 0; i < 1000; i++)
    {
        a[i] = -1 - i;                   //-1、-2...  當(dāng)執(zhí)行到a[127]=-1-127=-128后,下一次執(zhí)行 a[128]=-1-128=1111 1111+1000 0000=0111 1111(截?cái)嗪螅?127
                                    //127再繼續(xù)減減到0,該0之前元素個(gè)數(shù)即為strlen(a)的值=-1~-128+127~1=255

    }
    printf("%d\n", strlen(a));           //'\0'=0;即求0之前多少個(gè)元素。(strlen不帶\0)

以上就是“c++整數(shù)在內(nèi)存中的存儲(chǔ)方法是什么”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

新聞名稱:c++整數(shù)在內(nèi)存中的存儲(chǔ)方法是什么
轉(zhuǎn)載源于:http://www.chinadenli.net/article20/ieooco.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名定制開發(fā)網(wǎng)站營(yíng)銷搜索引擎優(yōu)化微信公眾號(hào)小程序開發(fā)

廣告

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

小程序開發(fā)