亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

c++整數在內存中的存儲方法是什么

發布時間:2022-01-07 20:21:46 來源:億速云 閱讀:380 作者:iii 欄目:編程語言

今天小編給大家分享一下c++整數在內存中的存儲方法是什么的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

存放格式
對整數來說,數據存放在內存中其實存放的是補碼。原因是在計算機系統中,數值一律補碼來表示和存儲,原因在于,使用補碼,可將符號位和數值域統一處理,同時,加法減法也可以統一處理(cpu只有加法器),此外,補碼和原碼相互轉換,運算過程完全相同,不需要額外的硬件電路。

大小端介紹
大段存儲模式:指數據的低權值位存放于內存的高地址,高權值位存放于內存的低地址。
小段存儲模式:指數據的高權值位存放于內存的高地址,低權值位存放于內存的低地址。

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

    system("pause");
    return 0;
}

在內存中進行加減過程
題一:

char a = -1;                 //原碼 1000 0001   補碼 1111 1111
    signed char b = -1;          //原碼 1000 0001   補碼 1111 1111
    unsigned char c = -1;        //原碼 1000 0001   補碼 1111 1111
                                               //%d char轉int型發生×××提升,有符號數發生×××提升前面補符號位,無符號數補0                 
    printf("a=%d\n", a);         //提升后  a=1111 1111 1111 1111 1111 1111 1111 1111 (補碼) 輸出原碼: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 (補碼) 輸出原碼:0000 0000 0000 0000 0000 0000 1111 1111 =255

題二:

1>
char a = -128;               //原碼 1 1000 0000  符號位溢出后截斷 變為1000 0000   補碼:1 1000 0000再次截斷1000 0000 
    printf("%u\n", a);           //×××提升:1111 1111 1111 1111 1111 1111 1000 0000 (補碼) 因為是無符號×××輸出,所以輸出該二進制對應的十進制數。

2>
char a = 128;                 //原碼:0 1000 0000  符號位溢出后截斷 變為1000 0000   補碼:1 1000 0000再次截斷1000 0000 
    printf("%u\n", a);            //由此可看出答案同上

題三:

unsigned char i = 0;           //表示數值范圍:0~255
    for (i = 0; i <= 255; i++)     //一直在0~255之間,當i=255再加1時,發生截斷后就又變為0了  1111 1111+0000 0001=1 | 0000 0000 =0
    {
        printf("%d\n", i);         //所以一直循環,(死循環)重復打印0~255
        if (i <= 250)
        {
            Sleep(30);
        }
        else{
            Sleep(1000);
        }
    }

題四:

unsigned int i ;           //表示數值范圍:0~2^32-1
    for (i = 9; i >=0; i--)     //一直在0~2^32-1之間,當i=0再減1時,發生截斷后就又變為0了  0000 0000 .... 0000 + 1111 ...1111=1111....1111 =1... 1111 因為是無符號數,所以為2^32-1
    {
        printf("%d\n", i);         //所以一直循環,(死循環)打印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...  當執行到a[127]=-1-127=-128后,下一次執行 a[128]=-1-128=1111 1111+1000 0000=0111 1111(截斷后)=127
                                    //127再繼續減減到0,該0之前元素個數即為strlen(a)的值=-1~-128+127~1=255

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

以上就是“c++整數在內存中的存儲方法是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

邵武市| 尚志市| 岳普湖县| 进贤县| 信丰县| 平利县| 时尚| 年辖:市辖区| 宿松县| 汝州市| 沽源县| 平安县| 牙克石市| 綦江县| 堆龙德庆县| 冷水江市| 岗巴县| 来安县| 梨树县| 上饶县| 教育| 克拉玛依市| 海城市| 敖汉旗| 阜康市| 沧源| 霞浦县| 陇西县| 大渡口区| 安溪县| 桃园市| 红原县| 六安市| 皮山县| 湛江市| 邢台市| 蒙城县| 普定县| 多伦县| 乐陵市| 遵义县|