C語言詳細(xì)解析有符號數(shù)與無符號數(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++11中條件標(biāo)量和互斥鎖應(yīng)用出現(xiàn)死鎖問題
這篇文章主要介紹了C++11中條件標(biāo)量和互斥鎖應(yīng)用出現(xiàn)死鎖思考,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)
這篇文章主要介紹了C++ 數(shù)據(jù)結(jié)構(gòu)線性表-數(shù)組實現(xiàn)的相關(guān)資料,需要的朋友可以參考下2017-06-06C語言實現(xiàn)常見進(jìn)制轉(zhuǎn)換的示例代碼
生活中最常見的進(jìn)制是十進(jìn)制,而有一類編程題會要求將十進(jìn)制轉(zhuǎn)換為其他進(jìn)制,本文將主要講述C語言中常見的幾類進(jìn)制轉(zhuǎn)換問題,希望對大家有所幫助2023-04-04