位運算符與其餘

0x00  前言web

  ----萬般皆苦,惟有自渡;人生苦短,我亦朝陽spa

0x01  機器數--二進制數it

機器數 數字在計算機中的二進制表示形式,且有對應的符號位
符號位 二進制數的最高位(第一位),且正數爲0,負數爲1。如00000110爲6,10000110爲-6
機器的字長

 機器內部設備一次能表示的二進制位數。編譯

8bit=1Byte,即,字節的整數倍爲字長,如8位、16位table

真值

帶符號位的機器數對應的真正數值。基礎

如二進制數10000110的真值爲爲二進制的-0000110,或十進制的-6,而不是134變量

 

 0x02  原碼,反碼,補碼等二進制

  概念 使用
原碼 符號位加上真值的絕對值 如-6的原碼爲10000110,8的原碼爲00001000
反碼

正數的反碼爲其自己,即與原碼相同;總結

負數的反碼爲原碼的基礎上, 符號位不變,其他各位取反(0和1互變)計算機

如-6的反碼爲11111001;6的反碼仍是00000110
補碼

正數的補碼爲其自己,即與原碼相同;

負數的補碼爲其反碼+1

數0的補碼錶示是惟一,即00000000

如-6的補碼爲11111010;8的補碼仍是00001000
總結

正數的原碼、反碼、補碼相同;負數的如上

 
負數的補碼轉十進制

一、各位取反;二、轉十進制;三、加符號,再-1

如11111010:一、00000101;    二、5;     三、-6

0x03  位運算符

表達式/聲明 二進制數 備註
int a=6; 00000110 定義整型變量
int b=11; 00001011  
a&b 00000010 按位與。有0爲0
a|b 00001111 按位或。有1爲1
a^b 00001101 按位異或。不一樣爲1
~a 11111001 取反。0和1互變
a>>2 00000001

a的二進制數都向右移2位。低位捨棄,高位:

a爲正數時,最高位補0

a爲負數時,最高位看編譯系統是補0/1

a<<2 00011000 a的二進制數都向左移2位。高位丟棄,低位補0

0x02  編外

  ----內容爲本人查閱資料理解,若有侵權,請及時聯繫本人

相關文章
相關標籤/搜索