溫馨提示×

溫馨提示×

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

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

java二進(jìn)制的相關(guān)基礎(chǔ)知識分享

發(fā)布時(shí)間:2021-09-01 21:40:54 來源:億速云 閱讀:136 作者:chen 欄目:編程語言

本篇內(nèi)容主要講解“java二進(jìn)制的相關(guān)基礎(chǔ)知識分享”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“java二進(jìn)制的相關(guān)基礎(chǔ)知識分享”吧!

說明

任何東西都有規(guī)范,提到JAVA就會提到2個(gè)規(guī)范,JAVA語言規(guī)范、JVM規(guī)范。JAVA語言規(guī)范主要定義JAVA的語法、變量、類型、文法等等,JVM規(guī)范主要定義Class文件類型、運(yùn)行時(shí)數(shù)據(jù)、幀棧、虛擬機(jī)的啟動、虛擬機(jī)的指令集等等。

  • JAVA語言規(guī)范主要定義什么是JAVA語言。

  • JVM規(guī)范主要定義JVM內(nèi)部實(shí)現(xiàn),二進(jìn)制class文件和JVM指令集等。

規(guī)范中數(shù)字的內(nèi)部表示和存儲

JAVA八種基本數(shù)據(jù)類型:

  • 整形:byte,short,int,long

  • 浮點(diǎn)型:float,double

  • 布爾型:boolean

  • 字符型:char

  • 數(shù)據(jù)類型 所占位數(shù)

數(shù)據(jù)類型所占位數(shù)
int32bit
short16bit
long64bit
byte8bit
char16bit
float32bit
double64bit
boolean1bit

備注:1字節(jié)=8位(1 byte = 8bit)

java二進(jìn)制的相關(guān)基礎(chǔ)知識分享

java二進(jìn)制的相關(guān)基礎(chǔ)知識分享

整數(shù)的表示

  • 源碼:第一位為符號位(0表示正數(shù),1表示負(fù)數(shù))。

  • 反碼:符號位不動,原碼取反。

  • 負(fù)數(shù)補(bǔ)碼:符號位不動,反碼加1。

  • 正數(shù)補(bǔ)碼:和源碼相同。

備注:補(bǔ)碼的好處:

使用補(bǔ)碼可以沒有任何歧義的表示0。

補(bǔ)碼可以很好的參與二進(jìn)制的運(yùn)算,補(bǔ)碼相加符號位參與運(yùn)算,這樣就簡單很多了。

浮點(diǎn)數(shù)表示

在上圖中,我們了解到Float與Double都是支持IEEE 754

我們以float來說明:

java二進(jìn)制的相關(guān)基礎(chǔ)知識分享

IEEE745單精度浮點(diǎn)格式共32位,包含三個(gè)構(gòu)成字段:23位小數(shù)f,8位偏置指數(shù)e,1位符號s。將這些字段連續(xù)存放在一個(gè)32位字里,并對其進(jìn)行編碼。其中0:22位包含23位的小數(shù)f; 23:30位包含8位指數(shù)e;第31位包含符號s。

java二進(jìn)制的相關(guān)基礎(chǔ)知識分享

一個(gè)實(shí)數(shù)V在IEEE 754標(biāo)準(zhǔn)中可以用V=(-1)s×M×2E 的形式表示,說明如下:

  • 符號s(sign)決定實(shí)數(shù)是正數(shù)(s=0)還是負(fù)數(shù)(s=1),對數(shù)值0的符號位特殊處理。

  • 有效數(shù)字M(significand)是二進(jìn)制小數(shù),M的取值范圍在1≤M<2或0≤M<1。

  • 指數(shù)E(exponent)是2的冪,它的作用是對浮點(diǎn)數(shù)加權(quán)。

符號位指數(shù)位小數(shù)位
1位8位23位

例如根據(jù)IEEE745,計(jì)算11000001000100000000000000000000的單精度浮點(diǎn)的值。

解題:

11000001000100000000000000000000
符號位指數(shù)尾數(shù)由于指數(shù)不是全部為0 所以小數(shù)位附加1
1100000101.00100000000000000000000
-12^(130-127)(2^0 + 2^-3)

結(jié)論:-1 * (2^0 + 2^-3) * 2^(130-127) =-9

同樣,你也可以驗(yàn)證一下十進(jìn)制浮點(diǎn)數(shù)0.1的二進(jìn)制形式是否正確,你會發(fā)現(xiàn),0.1不能表示為有限個(gè)二進(jìn)制位,因此在內(nèi)存中的表示是舍入(rounding)以后的結(jié)果,即 0x3dcccccd, 十進(jìn)制為0.100000001, 誤差0.000000001由此產(chǎn)生了。

進(jìn)制的概念

我們常用的進(jìn)制有二進(jìn)制、八進(jìn)制、十進(jìn)制和十六進(jìn)制,十進(jìn)制是最主要的表達(dá)形式。

二進(jìn)制是0和1;八進(jìn)制是0-7;十進(jìn)制是0-9;十六進(jìn)制是0-9+A-F(大小寫均可)。

位運(yùn)算符

按位與(&)

兩位全為1,結(jié)果才為1:

0&0=0;
0&1=0;
1&0=0;
1&1=1;

用法:

  • 清零:如果想要一個(gè)單位清零,那么使其全部二進(jìn)制為0,只要與一個(gè)各位都為零的數(shù)值想與,結(jié)果為零。

  • 取一個(gè)數(shù)中指定位:找一個(gè)數(shù),對應(yīng)X要取的位,該數(shù)的對應(yīng)位為1,其余位為零,此數(shù)與X進(jìn)行“與運(yùn)算”可以得到X中的指定位。

例如:設(shè)X=1010 1110,取X的低4位,用X & 0000 1111 = 0000 1110 就可以得到。

按位或(|)

只要有一個(gè)為1,結(jié)果就為1:

0|0=0;
0|1=1;
1|0=1;
1|1=1;

用法:常用來對一個(gè)數(shù)據(jù)的某些位置1;找到一個(gè)數(shù),對應(yīng)X要置1的位,該數(shù)的對應(yīng)位為1,其余位為零。此數(shù)與X相或可使X中的某些位置1。

例如:將X=1010 0000 的低四位置1,用X | 0000 1111 =1010 1111 就可以得到。

異或運(yùn)算(^)
*兩個(gè)相應(yīng)位為“異”(值不同),則該位結(jié)果為1,否則為0: *

0^0=0;
0^1=1;
1^0=1;
1^1=0;

用法:

  • 使特定位翻轉(zhuǎn):找一個(gè)數(shù),對應(yīng)X要翻轉(zhuǎn)的各位,該數(shù)的對應(yīng)位為1,其余位為零,此數(shù)與X對應(yīng)位異或就可以得到; 例如:X=1010 1110,使X低4位翻轉(zhuǎn),用X ^ 0000 1111 = 1010 0001就可以得到

  • 與0相異或,保留原值 例如:X ^ 0000 0000 = 1010 1110

  • 兩個(gè)變量交換值的方法: 1、借助第三個(gè)變量來實(shí)現(xiàn): C=A; A=B; B=C; 2、 利用加減法實(shí)現(xiàn)兩個(gè)變量的交換:A=A+B; B=A-B;A=A-B; 3、用位異或運(yùn)算來實(shí)現(xiàn):利用一個(gè)數(shù)異或本身等于0和異或運(yùn)算符合交換律 例如:A = A ^ B; B = A ^ B; A = A ^ B;

取反運(yùn)算(~)

對于一個(gè)二進(jìn)制數(shù)按位取反,即將0變1,1變0: ~1=0; ~0=1;

左移運(yùn)算(<<)

將一個(gè)運(yùn)算對象的各二進(jìn)制位全部左移若干位(左邊的二進(jìn)制丟棄,右邊補(bǔ)零) 2<<1 = 4 : 10 <<1 =100=4

若左移時(shí)舍棄的高位不包括1,則每左移一位,相當(dāng)于該數(shù)乘以2。 -14(二進(jìn)制:1111 0010)<< 2= (1100 1000) (高位包括1,不符合規(guī)則)

右移運(yùn)算(>>)

將一個(gè)數(shù)的各二進(jìn)制位全部右移若干位,正數(shù)左補(bǔ)0,負(fù)數(shù)左補(bǔ)1,右邊丟棄。操作數(shù)每右移一位,相當(dāng)于該數(shù)除以2.

左補(bǔ)0 or 補(bǔ)1 得看被移數(shù)是正還是負(fù)。

例:4 >> 2 = 1

例:-14(1111 0010) >> 2 = -4 (1111 1100 )

無符號右移運(yùn)算(>>>)

各個(gè)位向右移指定的位數(shù)。右移后左邊突出的位用零來填充。移出右邊的位被丟棄

各個(gè)位向右移指定的位數(shù)。右移后左邊突出的位用零來填充。移出右邊的位被丟棄

例如: -14>>>2

即-14(1111 1111 1111 1111 1111 1111 1111 0010)>>> 2

=(0011 1111 1111 1111 1111 1111 1111 1100)

= 1073741820

說明:

  • 0x80000000是數(shù)的十六進(jìn)制表示,轉(zhuǎn)成二進(jìn)制表示為10000000000000000000000000000000

  • 運(yùn)算的優(yōu)先級,移位運(yùn)算高于邏輯運(yùn)算,>>>高于&

  • 位邏輯與運(yùn)算 1&1 = 1 ,0&1 = 0

  • >>>無符號右移,移出部分舍棄,左邊位補(bǔ)0;

到此,相信大家對“java二進(jìn)制的相關(guān)基礎(chǔ)知識分享”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI