也難怪瓊不知道。
浮點運算這東西是在計算機發展一段時間后才針對有限存儲空間提高其靈活性和運算范圍發明出來的。
此時的瓊還有遠在日不落的圖靈,他們雖然有足夠的智商發明這種運算,但此時他們的注意力主要集中在“克里斯托弗”本身,而且主要針對其解碼方面的用途,于是就沒有考慮到這一點。
認識十年的老書友給我推薦的追書a,野果閱讀真特么好用,開車、睡前都靠這個朗讀聽書打發時間,這里可以下載
“這么說吧”王學新帶著幾個人來到防空洞門邊的辦公桌前,拿過桌上的紙和筆一邊寫著一邊解釋道“如果我們使用16位運算帶小數的數據,按常規的運算方式應該是將一半的存儲單元也就是7位配給整數,另8位分配給小數,對嗎”
“沒錯”瓊點了點頭。
之所以整數位只有7位,是因為數據通常有正有負,要空出一位表示正負0表示正,1表示負,這一位也被稱作是符號位。
“這樣的存儲法很多時候會出現空間和時間的浪費”王學新接著說道“它的整數位固定只有7位小數位固定只有8位,如果有個數據是123456678,雖然它只有8位數而我們的存儲單元有16個,但卻存不下這個數字”
這是因為整數位只有7位的原因,所以一個八位數已經超出它的儲存范圍了,盡管小數位的8個儲存單元一個數字都沒存。
同理,如果整數位一個數字都沒有,小數位卻在第九位上,也無法有效儲存進行運算。
瓊點頭道“這就是我想說的,我們應該要擴展到32個存儲單元,之前用機械零件要做到這一點很困難,現在改用繼電器做零件了,同樣的條件完全能實現32位為什么不做”
“等等,瓊”王學新說“你先聽我說完”
瓊點了下頭然后就不說話了。
王學新接著說道“這是傳統的儲存方式,我們姑且把它稱作定點運算。浮點運算的意思是,我們把其中幾位,比如四位用來存儲次方”
“存儲次方”瓊吃驚的望向王學新“但它們通常沒有次方”
陳班兩人也疑惑不解,他們不明白這樣轉換會有什么用。
王學新舉了個例子“比如剛才的數據12345678,我們為什么不能把它變成123456678乘以10的7次方然后我們的整數和小數的存儲空間就可以隨意利用,簡單的說,就是小數沒有用到的存儲空間就可以用這方法變換到整數利用,整數沒有用到的存儲空間可以變換到小數去利用”
瓊聽著不由恍然大悟。
“說得對,團長同志”瓊說“這樣一來,任何時候我們的存儲空間都有11位,可以存下任何一個11位數而不是定點運算的7位整位或8位小數。”
“是的”王學新點了點頭,說“實際上,如果把它轉換為二進制并把所有的數字都轉換成1xxxx的形式并只存小數點后的數字的話,我們還可以多存一位也就是12位”
這有點難理解。