C語(yǔ)言詳細(xì)解析有符號(hào)數(shù)與無符號(hào)數(shù)的表示
一、計(jì)算機(jī)中的符號(hào)位
數(shù)據(jù)類型的最高位用于標(biāo)識(shí)數(shù)據(jù)的符號(hào)
- 最高位為1,表明這個(gè)數(shù)為負(fù)數(shù)
- 最高位為0,表明這個(gè)數(shù)為正數(shù)
下面看一段代碼,用于判斷數(shù)據(jù)的符號(hào):
#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 。
二、有符號(hào)數(shù)的表示法
在計(jì)算機(jī)內(nèi)部用補(bǔ)碼表示有符號(hào)數(shù)
- 正數(shù)的補(bǔ)碼為正數(shù)本身
- 負(fù)數(shù)的補(bǔ)碼為負(fù)數(shù)的絕對(duì)值各位取反后加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
三、無符號(hào)數(shù)的表示法
在計(jì)算機(jī)內(nèi)部用原碼表示無符號(hào)數(shù)
- 無符號(hào)數(shù)默認(rèn)為正數(shù)
- 無符號(hào)數(shù)沒有符號(hào)位
對(duì)于固定長(zhǎng)度的無符號(hào)數(shù)
- MAX_VALUE(所能表示的最大值)+ 1 --> MIN_VALUE(所能表示的最小值)
- MIN_VALUE - 1 --> MAX_VALUE
四、signed 和 unsigned
- C 語(yǔ)言中變量默認(rèn)為有符號(hào)的類型
- unsigned 關(guān)鍵字聲明變量為無符號(hào)類型
注意:C語(yǔ)言中只有整數(shù)類型能夠聲明 unsigned 變量
下面看一段無符號(hào)數(shù)碰上有符號(hào)數(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,為什么會(huì)大于 0 呢?這是因?yàn)楫?dāng)無符號(hào)數(shù)與有符號(hào)數(shù)混合計(jì)算時(shí),會(huì)將有符號(hào)數(shù)轉(zhuǎn)換為無符號(hào)數(shù)后再進(jìn)行計(jì)算,結(jié)果為無符號(hào)數(shù)。
再來看一個(gè)錯(cuò)誤使用 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,就變成了最大值,所以程序就會(huì)這樣輸出。
五、小結(jié)
有符號(hào)數(shù)用補(bǔ)碼表示
- 正數(shù)的符號(hào)位為0
- 負(fù)數(shù)的符號(hào)位為1
無符號(hào)數(shù)用原碼表示
- 無符號(hào)數(shù)沒有符號(hào)位
- 無符號(hào)數(shù)只用于表示正數(shù)
unsigned 只能修飾整數(shù)類型的變量
到此這篇關(guān)于C語(yǔ)言詳細(xì)解析有符號(hào)數(shù)與無符號(hào)數(shù)的表示的文章就介紹到這了,更多相關(guān)C語(yǔ)言有符號(hào)數(shù)與無符號(hào)數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
c++入門必學(xué)算法之快速冪思想及實(shí)現(xiàn)
快速冪相較于普通的冪,具有占用空間少,效率更高等優(yōu)點(diǎn),全面碾壓普通的冪,下面這篇文章主要給大家介紹了關(guān)于c++入門必學(xué)算法之快速冪思想及實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2022-11-11
詳解C語(yǔ)言中g(shù)etgid()函數(shù)和getegid()函數(shù)的區(qū)別
這篇文章主要介紹了詳解C語(yǔ)言中g(shù)etgid()函數(shù)和getegid()函數(shù)的區(qū)別,注意getegid只返回有效的組識(shí)別碼,需要的朋友可以參考下2015-08-08
如何在c++中實(shí)現(xiàn)字符串分割函數(shù)split詳解
這篇文章主要給大家介紹了關(guān)于如何在c++中實(shí)現(xiàn)字符串分割函數(shù)split的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用c++具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
C++11中隱式類型轉(zhuǎn)換的實(shí)現(xiàn)示例
C++類型轉(zhuǎn)換分為:隱式類型轉(zhuǎn)換和顯式類型轉(zhuǎn)換,本文主要介紹了C++11中隱式類型轉(zhuǎn)換的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-06-06
C++ Coroutine簡(jiǎn)單學(xué)習(xí)教程
這篇文章主要為大家詳細(xì)介紹了C++ Coroutine的簡(jiǎn)單學(xué)習(xí)教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
C++ DFS算法實(shí)現(xiàn)走迷宮自動(dòng)尋路
這篇文章主要為大家詳細(xì)介紹了C++ DFS算法實(shí)現(xiàn)走迷宮自動(dòng)尋路,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05
C語(yǔ)言關(guān)系運(yùn)算符實(shí)例詳解
本文主要介紹C語(yǔ)言的關(guān)系運(yùn)算符的知識(shí),這里提供實(shí)例代碼以便參考,希望能幫助有需要的小伙伴2016-07-07

