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

C語言詳細(xì)解析有符號數(shù)與無符號數(shù)的表示

 更新時間:2022年04月20日 16:53:20   作者:清風(fēng)自在?流水潺潺  
我們知道,在C語言中存在無符號數(shù)和有符號數(shù),但是對于計算機(jī)而言,其本身并不區(qū)別有符號數(shù)和無符號數(shù),因為在計算機(jī)里面都是O或者1,但是在我們的實際使用中有時候需要使用有符號數(shù)來表示一個整數(shù),因此我們規(guī)定,當(dāng)最高位為1的時,表示為負(fù)數(shù),最高位為0時,表示為正數(shù)

一、計算機(jī)中的符號位

數(shù)據(jù)類型的最高位用于標(biāo)識數(shù)據(jù)的符號

  • 最高位為1,表明這個數(shù)為負(fù)數(shù)
  • 最高位為0,表明這個數(shù)為正數(shù)

下面看一段代碼,用于判斷數(shù)據(jù)的符號:

#include <stdio.h>
int main()
{
    char c = -5;
    short s = 6;
    int i = -7;
    printf("%d\n", ( (c & 0x80) != 0 ));
    printf("%d\n", ( (s & 0x8000) != 0 ));
    printf("%d\n", ( (i & 0x80000000) != 0 ));
    return 0;
}

下面為輸出結(jié)果:

這段代碼核心思想就是判斷最高位為是不是 1,再做邏輯運(yùn)算,如果為 1,那么運(yùn)算后就是 1,否則就是 0 。

二、有符號數(shù)的表示法

在計算機(jī)內(nèi)部用補(bǔ)碼表示有符號數(shù)

  • 正數(shù)的補(bǔ)碼為正數(shù)本身
  • 負(fù)數(shù)的補(bǔ)碼為負(fù)數(shù)的絕對值各位取反后加1

如:

8位整數(shù) 5 的補(bǔ)碼為:0000 0101

8位整數(shù) -7 的補(bǔ)碼為:11111001

16位整數(shù) 20 的補(bǔ)碼為:0000 0000 0001 0100

16位整數(shù)- 13 的補(bǔ)碼為:1111 1111 1111 0011

三、無符號數(shù)的表示法

在計算機(jī)內(nèi)部用原碼表示無符號數(shù)

  • 無符號數(shù)默認(rèn)為正數(shù)
  • 無符號數(shù)沒有符號位

對于固定長度的無符號數(shù)

  • MAX_VALUE(所能表示的最大值)+ 1 --> MIN_VALUE(所能表示的最小值)
  • MIN_VALUE - 1 --> MAX_VALUE

四、signed 和 unsigned

  • C 語言中變量默認(rèn)為有符號的類型
  • unsigned 關(guān)鍵字聲明變量為無符號類型

注意:C語言中只有整數(shù)類型能夠聲明 unsigned 變量

下面看一段無符號數(shù)碰上有符號數(shù)的代碼:

#include <stdio.h>
int main()
{
    unsigned int i = 5;
    int j = -10;
    if( (i + j) > 0 )
    {
        printf("i + j > 0\n");
    }
    else
    {
        printf("i + j <= 0\n");
    }
    return 0;
}

下面為輸出結(jié)果:

i 為 5,j 為 -10,按理說兩者相加應(yīng)該輸出為 i + j < 0,為什么會大于 0 呢?這是因為當(dāng)無符號數(shù)與有符號數(shù)混合計算時,會將有符號數(shù)轉(zhuǎn)換為無符號數(shù)后再進(jìn)行計算,結(jié)果為無符號數(shù)。

再來看一個錯誤使用 unsigned 的例子:

#include <stdio.h>
int main()
{
    unsigned int i = 0;
    for(i=9; i>=0; i--)
    {
        printf("i = %u\n", i);
    }
    return 0;
}

下面為部分輸出結(jié)果:

這是由于 i 為 unsigned 類型,減到 0 后,再減1,就變成了最大值,所以程序就會這樣輸出。

五、小結(jié)

有符號數(shù)用補(bǔ)碼表示

  • 正數(shù)的符號位為0
  • 負(fù)數(shù)的符號位為1

無符號數(shù)用原碼表示

  • 無符號數(shù)沒有符號位
  • 無符號數(shù)只用于表示正數(shù)

unsigned 只能修飾整數(shù)類型的變量

到此這篇關(guān)于C語言詳細(xì)解析有符號數(shù)與無符號數(shù)的表示的文章就介紹到這了,更多相關(guān)C語言有符號數(shù)與無符號數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++中的異常實例詳解

    C++中的異常實例詳解

    異常處理是C++的一項語言機(jī)制,用于在程序中處理異常事件,下面這篇文章主要給大家介紹了關(guān)于C++中異常的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-02-02
  • C++實現(xiàn)簡易通訊錄管理系統(tǒng)

    C++實現(xiàn)簡易通訊錄管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)簡易通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • c語言switch反匯編的實現(xiàn)

    c語言switch反匯編的實現(xiàn)

    本文主要介紹了c語言switch反匯編,在分支較多的時候,switch的效率比if高,在反匯編中我們即可看到效率高的原因,感興趣的可以了解一下
    2021-06-06
  • 詳解C++基礎(chǔ)——類繼承

    詳解C++基礎(chǔ)——類繼承

    這篇文章主要介紹了C++類繼承,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 詳解C語言之實現(xiàn)通訊錄

    詳解C語言之實現(xiàn)通訊錄

    這篇文章主要為大家詳細(xì)介紹了用C語言實現(xiàn)通訊錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C/C++實現(xiàn)獲取硬盤序列號的示例代碼

    C/C++實現(xiàn)獲取硬盤序列號的示例代碼

    獲取硬盤的序列號、型號和固件版本號,此類功能通常用于做硬盤綁定或硬件驗證操作,下面我們就來學(xué)習(xí)一下如何使用C/C++實現(xiàn)獲取硬盤序列號吧
    2023-11-11
  • C++連接并使用MySQL數(shù)據(jù)庫

    C++連接并使用MySQL數(shù)據(jù)庫

    這篇文章主要為大家詳細(xì)介紹了C++連接并使用MySQL數(shù)據(jù)庫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • C++11中條件標(biāo)量和互斥鎖應(yīng)用出現(xiàn)死鎖問題

    C++11中條件標(biāo)量和互斥鎖應(yīng)用出現(xiàn)死鎖問題

    這篇文章主要介紹了C++11中條件標(biāo)量和互斥鎖應(yīng)用出現(xiàn)死鎖思考,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)

    C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)

    這篇文章主要介紹了C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • C語言實現(xiàn)常見進(jìn)制轉(zhuǎn)換的示例代碼

    C語言實現(xiàn)常見進(jìn)制轉(zhuǎn)換的示例代碼

    生活中最常見的進(jìn)制是十進(jìn)制,而有一類編程題會要求將十進(jìn)制轉(zhuǎn)換為其他進(jìn)制,本文將主要講述C語言中常見的幾類進(jìn)制轉(zhuǎn)換問題,希望對大家有所幫助
    2023-04-04

最新評論