0的源碼
1. 在原碼表示中,為什麼+0的原碼為00000除了符號0,後面還有4個0,而不是有5、8....個呢
1.二進製表示用多少個0或1是取決於機器字長的;
機器字長是指計算機進行一次整數運算所能處理的二進制數據的位數。說白了就類似吞吐量~要是8bits的,那一次就能處理8位~所以後面有幾個0(1)是取決於機器字長的~
2.正數的補碼是其本身,也就是原碼.負數的補碼是各位取反後加1.也就是其反碼加1.
假設機器字長是8位:
+0的補碼就是其原碼,也就是說是0000 0000而已
-0的補碼是其反碼加1,其反碼是1111 1111,當然,其反碼加1後就是溢出一個進位後,仍然是0000 0000.
所以:+0與-0的補碼都是00000000
你把補碼,反碼的概念好好看看就能明白了~
反碼表示法規定:正數的反碼與其原碼相同;負數的反碼是對其原碼逐位取反,但符號位除外。
補碼表示法規定:正數的補碼與其原碼相同;負數的補碼是在其反碼的末位加1。
其實要是理解了~就一下子明白了~~
2. 請問+0和-0的原碼,反碼和補碼分別是什麼
如果是在字長為8位的計算機上,
+0的原碼是00000000 -0的原碼是10000000
+0的反碼是00000000 -0的反碼是11111111
+0和-0的補碼均為00000000
3. 請問+0和-0的原碼,反碼和補碼分別是什麼
針對一個數字,可以求出各種碼。
數字,只有:負數、零、正數。
數字中,從來就沒有+0、-0!
----
0 的原碼,有兩種:0000 0000、1000 0000。
0 的反碼也有兩種:0000 0000、1111 1111。
有人就簡稱:+0、-0。
它們,已經是原(反)碼,並不是數了。
你不能說:+0 和-0 的原碼、反碼。
你只能問:0 的原碼、反碼和補碼是什麼。
4. 0的原碼,補碼,反碼是什麼
0在計算機種分+0與-0,它們的原碼,補碼,反碼如下:
1、[+0]原碼=0000 0000, [-0]原碼=1000 0000;
2、[+0]反碼=0000 0000, [-0]反碼=1111 1111;
3、[+0]補碼=0000 0000, [-0]補碼=0000 0000。
在這里你會發現,+0和-0的補碼是一樣的,即0的補碼只有一種表示。
在計算機內,符號數有3種表示法:原碼、反碼和補碼。
(4)0的源碼擴展閱讀:
原碼、補碼、反碼的轉換規則:
1、原碼的求法:
(1)對於正數,轉化為二進制數,在最前面添加一符號位(這是規定的),用1表示負數,0表示正數,如:0000 0000是一個位元組,其中左邊第一個0,0為符號位,表示是正數,其它七位表示二進制的值。
(2)正數的原碼、反碼、補碼是同一個數。
(3)對於負數,轉化為二進制數,前面符號位為1,1表示是負數。
2、計算原碼只要在轉化的二進制數前面加上相應的符號位就行了。
3、反碼的求法:
對於負數,將原碼各位取反,符號位不變。
4、補碼的求法:
對於負數,將反碼加上二進制的1即可,也就是反碼在最後一位上加上1就是補碼了。
5. +0或者-0的源碼、反碼、補碼
[+0]原碼=0000 0000, [-0]原碼=1000 0000
[+0]反碼=0000 0000, [-0]反碼=1111 1111
[+0]補碼=0000 0000, [-0]補碼=0000 0000
補碼沒有正0與負0之分。正數的反碼、補碼和其源碼相同,負數的反碼是其源碼,除符號位外其他位取反負數的補碼是取其反碼後加1。
詳細釋義:
所謂原碼就是二進制定點表示法,即最高位為符號位,「0」表示正,「1」表示負,其餘位表示數值的大小。
(一)反碼表示法規定:
1、正數的反碼與其原碼相同;
2、負數的反碼是對正數逐位取反,符號位保持為1;
(二)對於二進制原碼10010求反碼:
((10010)原)反=對正數(00010)原含符號位取反= 反碼11101 (10010,1為符號碼,故為負)
(11101) 二進制= -2 十進制
(三)對於八進制:
舉例 某linux平台設置了默認的目錄許可權為755(rwxr-xr-x),八進製表示為0755,那麼,umask是許可權位755的反碼,計算得到umask為0022的過程如下:
原碼0755= 反碼 0022 (逐位解釋:0為符號位,0為7-7,2為7-5,2為7-5)
(四)補碼表示法規定:正數的補碼與其原碼相同;負數的補碼是在其反碼的末位加1。
(5)0的源碼擴展閱讀
轉換方法
由於正數的原碼、補碼、反碼表示方法均相同,不需轉換。在此,僅以負數情況分析。
(1) 已知原碼,求補碼。
例:已知某數X的原碼為10110100B,試求X的補碼和反碼。
解:由[X]原=10110100B知,X為負數。求其反碼時,符號位不變,數值部分按位求反;求其補碼時,再在其反碼的末位加1。
1 0 1 1 0 1 0 0 原碼
1 1 0 0 1 0 1 1 反碼,符號位不變,數值位取反
1 +1
1 1 0 0 1 1 00 補碼
故:[X]補=11001100B,[X]反=11001011B。
(2) 已知補碼,求原碼。
分析:按照求負數補碼的逆過程,數值部分應是最低位減1,然後取反。但是對二進制數來說,先減1後取反和先取反後加1得到的結果是一樣的,故仍可採用取反加1 有方法。
例:已知某數X的補碼11101110B,試求其原碼。
解:由[X]補=11101110B知,X為負數。
採用逆推法
1 1 1 0 1 1 1 0 補碼
1 1 1 0 1 1 0 1 反碼(末位減1)
1 0 0 1 0 0 1 0 原碼(符號位不變,數值位取反)
6. +0或者-0的源碼、反碼、補碼分別是什麼補碼是一樣的嗎
0原碼是00000000
-0原碼是10000000
0反碼是00000000
-0反碼是11111111
0補碼是00000000
補碼沒有正0與負0之分
正數的反碼、補碼和其原碼相同負數的反碼是其原碼除符號位外其他位取反負數的補碼是取其反碼後加1
7. 0 的原碼有幾個
0原碼是00000000 -0原碼是10000000 0反碼是00000000 -0反碼是11111111 0補碼是00000000
8. +10110的原碼
正數的原碼、補碼是其本身。
所以+10110的原碼 即0001 0110
9. 0.5 和 -0.5 的原碼表示的疑惑
①0.5原碼計算過程:0.5*2=1.0,故0.5原碼=0.1000000;
②0.625原碼計算過程:0.625*2=1.25,記錄小數點後第一位為1,然後將1.25-1=0.25再進行乘2操作,0.25*2*2=1.0,記錄小數點後第三位為1,故0.625原碼=0.1010000;
③-0.5原碼和-0.625原碼在對應絕對值原碼的小數點前第一位改為1即可;
10. 0的原碼、反碼、補碼是什麼
計算機中的存儲系統都是用2進制儲存的,對我們輸入的每一個信息它都會自動轉變成二進制的形式,而二進制在存儲的時候就會用到原碼,反碼和補碼 例如:輸入25 原碼就是:0000000000011001 反碼: 1111111111100110 補碼: 1111111111100111 ~ 數值在計算機中表示形式為機器數,計算機只能識別0和1,使用的是二進制,而在日常生活中人們使用的是十進制,"正如亞里士多德早就指出的那樣,今天十進制的廣泛採用,只不過我們絕大多數人生來具有10個手指頭這個解剖學事實的結果.盡管在歷史上手指計數(5,10進制)的實踐要比二或三進制計數出現的晚."(摘自<<數學發展史>>有空大家可以看看哦~,很有意思的).為了能方便的與二進制轉換,就使用了十六進制(2 4)和八進制(23).下面進入正題. 數值有正負之分,計算機就用一個數的最高位存放符號(0為正,1為負).這就是機器數的原碼了.假設機器能處理的位數為8.即字長為1byte,原碼能表示數值的范圍為 (-127~-0 +0~127)共256個. 有了數值的表示方法就可以對數進行算術運算.但是很快就發現用帶符號位的原碼進行乘除運算時結果正確,而在加減運算的時候就出現了問題,如下: 假設字長為8bits ( 1 ) 10- ( 1 )10 = ( 1 )10 + ( -1 )10 = ( 0 )10 (00000001)原 + (10000001)原 = (10000010)原 = ( -2 ) 顯然不正確. 因為在兩個整數的加法運算中是沒有問題的,於是就發現問題出現在帶符號位的負數身上,對除符號位外的其餘各位逐位取反就產生了反碼.反碼的取值空間和原碼相同且一一對應. 下面是反碼的減法運算: ( 1 )10 - ( 1 ) 10= ( 1 ) 10+ ( -1 ) 10= ( 0 )10 (00000001) 反+ (11111110)反 = (11111111)反 = ( -0 ) 有問題. ( 1 )10 - ( 2)10 = ( 1 )10 + ( -2 )10 = ( -1 )10 (00000001) 反+ (11111101)反 = (11111110)反 = ( -1 ) 正確 問題出現在(+0)和(-0)上,在人們的計算概念中零是沒有正負之分的.(印度人首先將零作為標記並放入運算之中,包含有零號的印度數學和十進制計數對人類文明的貢獻極大). 於是就引入了補碼概念. 負數的補碼就是對反碼加一,而正數不變,正數的原碼反碼補碼是一樣的.在補碼中用(-128)代替了(-0),所以補碼的表示範圍為: (-128~0~127)共256個. 注意:(-128)沒有相對應的原碼和反碼, (-128) = (10000000) 補碼的加減運算如下: ( 1 ) 10- ( 1 ) 10= ( 1 )10 + ( -1 )10 = ( 0 )10 (00000001)補 + (11111111)補 = (00000000)補 = ( 0 ) 正確 ( 1 ) 10- ( 2) 10= ( 1 )10 + ( -2 )10 = ( -1 )10 (00000001) 補+ (11111110) 補= (11111111)補 = ( -1 ) 正確 所以補碼的設計目的是: ⑴使符號位能與有效值部分一起參加運算,從而簡化運算規則. ⑵使減法運算轉換為加法運算,進一步簡化計算機中運算器的線路設計 所有這些轉換都是在計算機的最底層進行的,而在我們使用的匯編、C等其他高級語言中使用的都是原碼
求採納