第五章信息編碼_第1頁
第五章信息編碼_第2頁
第五章信息編碼_第3頁
第五章信息編碼_第4頁
第五章信息編碼_第5頁
已閱讀5頁,還剩23頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

第五章信息編碼5.1計算機的編碼與數(shù)據(jù)5.2進制及其轉(zhuǎn)換5.3計算機中信息的表示及存儲5.1計算機的編碼與數(shù)據(jù)計算機能夠處理數(shù)值、文字、聲音、圖像等各種信息。目前計算機中所有的信息都用“0”和“1”兩個數(shù)字符號組合的二進制數(shù)來表示。數(shù)值、圖形、文字等各種形式的信息,需要計算機進行加工處理時,首先必須按一定的法則轉(zhuǎn)換成二進制數(shù)。5.1.1計算機編碼1、ASCII碼在計算機內(nèi)部,所有的信息最終都表示為一個二進制的字符串。每一個二進制位(bit)有0和1兩種狀態(tài),因此八個二進制位就可以組合出256種狀態(tài),這被稱為一個字節(jié)(byte)。也就是說,一個字節(jié)一共可以用來表示256種不同的狀態(tài),每一個狀態(tài)對應一個符號,就是256個符號,從0000000到11111111。上個世紀60年代,美國制定了一套字符編碼,對英語字符與二進制位之間的關系,做了統(tǒng)一規(guī)定。這被稱為ASCII碼,一直沿用至今。

ASCII碼一共規(guī)定了128個字符的編碼,比如空格“SPACE”是32(二進制00100000),大寫的字母A是65(二進制01000001)。這128個符號(包括32個不能打印出來的控制符號),只占用了一個字節(jié)的后面7位,最前面的1位統(tǒng)一規(guī)定為0。下圖5-1為部分字符對應的ASCII。2、非ASCII編碼英語用128個符號編碼就夠了,但是用來表示其他語言,128個符號是不夠的。比如,在法語中,字母上方有注音符號,它就無法用ASCII碼表示。于是,一些歐洲國家就決定,利用字節(jié)中閑置的最高位編入新的符號。比如,法語中的é的編碼為130(二進制10000010)。這樣一來,這些歐洲國家使用的編碼體系,可以表示最多256個符號。但是,這里又出現(xiàn)了新的問題。不同的國家有不同的字母,因此,哪怕它們都使用256個符號的編碼方式,代表的字母卻不一樣。比如,130在法語編碼中代表了é,在希伯來語編碼中卻代表了字母Gimel(?),在俄語編碼中又會代表另一個符號。但是不管怎樣,所有這些編碼方式中,0—127表示的符號是一樣的,不一樣的只是128—255的這一段。至于亞洲國家的文字,使用的符號就更多了,漢字就多達10萬左右。一個字節(jié)只能表示256種符號,肯定是不夠的,就必須使用多個字節(jié)表達一個符號。比如,簡體中文常見的編碼方式是GB2312,使用兩個字節(jié)表示一個漢字,所以理論上最多可以表示256x256=65536個符號。3.Unicode

正如上一節(jié)所說,世界上存在著多種編碼方式,同一個二進制數(shù)字可以被解釋成不同的符號。因此,要想打開一個文本文件,就必須知道它的編碼方式,否則用錯誤的編碼方式解讀,就會出現(xiàn)亂碼。為什么電子郵件常常出現(xiàn)亂碼?就是因為發(fā)信人和收信人使用的編碼方式不一樣??梢韵胂?,如果有一種編碼,將世界上所有的符號都納入其中。每一個符號都給予一個獨一無二的編碼,那么亂碼問題就會消失。這就是Unicode,就像它的名字都表示的,這是一種所有符號的編碼。

Unicode當然是一個很大的集合,現(xiàn)在的規(guī)??梢匀菁{100多萬個符號。每個符號的編碼都不一樣,比如,U+0639表示阿拉伯字母Ain,U+0041表示英語的大寫字母A,U+4E25表示漢字“嚴”。具體的符號對應表,可以查詢unicode-org,或者專門的漢字對應表。4.UTF-8

互聯(lián)網(wǎng)的普及,強烈要求出現(xiàn)一種統(tǒng)一的編碼方式。UTF-8就是在互聯(lián)網(wǎng)上使用最廣的一種unicode的實現(xiàn)方式。其他實現(xiàn)方式還包括UTF-16和UTF-32,不過在互聯(lián)網(wǎng)上基本不用。重復一遍,這里的關系是,UTF-8是Unicode的實現(xiàn)方式之一。

UTF-8最大的一個特點,就是它是一種變長的編碼方式。它可以使用1~4個字節(jié)表示一個符號,根據(jù)不同的符號而變化字節(jié)長度。UTF-8的編碼規(guī)則很簡單,只有二條:1)對于單字節(jié)的符號,字節(jié)的第一位設為0,后面7位為這個符號的unicode碼。因此對于英語字母,UTF-8編碼和ASCII碼是相同的。2)對于n字節(jié)的符號(n>1),第一個字節(jié)的前n位都設為1,第n+1位設為0,后面字節(jié)的前兩位一律設為10。剩下的沒有提及的二進制位,全部為這個符號的unicode碼。下表總結了編碼規(guī)則,字母x表示可用編碼的位。Unicode符號范圍|UTF-8編碼方式

(十六進制)|(二進制)--------------------+---------------------------------------------00000000-0000007F|0xxxxxxx

00000080-000007FF|110xxxxx10xxxxxx

00000800-0000FFFF|1110xxxx10xxxxxx10xxxxxx

00010000-0010FFFF|11110xxx10xxxxxx10xxxxxx

10xxxxxx下面,還是以漢字“嚴”為例,演示如何實現(xiàn)UTF-8編碼。已知“嚴”的unicode是4E25(100111000100101),根據(jù)上表,可以發(fā)現(xiàn)4E25處在第三行的范圍內(nèi)(00000800-0000FFFF),因此“嚴”的UTF-8編碼需要三個字節(jié),即格式是“1110xxxx10xxxxxx10xxxxxx”。然后,從“嚴”的最后一個二進制位開始,依次從后向前填入格式中的x,多出的位補0。這樣就得到了,“嚴”的UTF-8編碼是“111001001011100010100101”,轉(zhuǎn)換成十六進制就是E4B8A5。5.1.2漢字存放標準GB23125.2進制及其轉(zhuǎn)換5.2.1進制概述十進制:日常生活中使用的數(shù)是十進制數(shù),它的特征是:有10個數(shù)字:0、1、2、3、4、5、6、7、8、9。運算時逢十進一。每個數(shù)字在不同的數(shù)位上,其值以10的倍數(shù)增。數(shù)位:個十百千萬……

數(shù)值:100101102103104……二進制;計算機使用的是二進制數(shù),它的特征是:有2個數(shù)字:0,1。運算時逢二進一。每個數(shù)字在不同數(shù)位上,其值以2的倍數(shù)遞增。即20,21,22,23,24,……

用二進制數(shù)表示一個數(shù)值時,因為其位數(shù)比較長,不便書寫和記憶;由于又有下面的關系:23=824=16所以人們常用八進制數(shù)或十六進制數(shù)來表示二進制數(shù)。八進制數(shù):有八個數(shù)字:0,1,2,3,4,5,6,7。運算時逢八進一。十六進制數(shù):有十六個數(shù)字:0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F(xiàn)。運算時逢十六進一。在十六進制中,分別用A、B、C、D、E和F來表示十進制數(shù)的10、11、12、13、14和15。由此可得出:二進制、八進制、十進制與十六進制的特征對照表如表5-1所示。表5-1二進制、八進制、十進制與十六進制的特征對照表進制個位數(shù)字運算規(guī)則數(shù)的表示方法二進制0、1逢二進一(1101)2八進制0、1、2、3、4、5、6、7逢八進一(17)8十進制0、1、2、3、4、5、6、7、8、9逢十進一(23)10十六進制0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F逢十六進一(2F)16表5-2二進制、八進制、十進制與十六進制的特征5.2.2進制間的轉(zhuǎn)換進制間的轉(zhuǎn)換有兩種方式可以完成,第一種,通過豎式計算可以進行,這種方式相對比較復雜,理解有一定的難度,相對抽象點;第二種方式可以通過“程序”菜單欄中的“計算器”工具可以直接轉(zhuǎn)換,這種轉(zhuǎn)換比較直觀,結果準確度高。下面詳細敘述這兩種轉(zhuǎn)換方式的轉(zhuǎn)換過程。第一種轉(zhuǎn)換方式、計算的方式完成進制的轉(zhuǎn)換

R(R表示二、八、十六)進制轉(zhuǎn)換成十進制:任何一個數(shù)一般由:數(shù)值、位權與基數(shù)組成?!盎鶖?shù)”即為該數(shù)字采用何種進制,則對應的基數(shù)就是幾,如(101101)2表示采用二進制,則基數(shù)即為“2”。“位權”是以小數(shù)點為基準,向左每一位數(shù)字的位權從0開始變化,依次遞增1,分別為0、1、2……;向右依次遞減,分別為-1、-2……如(82.35)10中“8”的位權為1,“2”的位權為0,“3”的位權為-1,“5”的位權為-2。“數(shù)值”是指個、十、百位上的數(shù)字。例1:將二進制數(shù)(101101)2轉(zhuǎn)換成十進制數(shù)。先確定二進制數(shù)(101101)2中的位權從左到右依次為5、4、3、2、1、0,由于基數(shù)為“2”,所以轉(zhuǎn)換后的十進制數(shù)應為:(101101)2=1х25+0х24+1х23+1х22+0х21+1х20=45例2:將十六進制(2AF5)16換算成10進制:第0位:5*160=5第1位:F*161=240第2位:A*162=2560第3位:2*163=8192+————————————-10997十進制數(shù)轉(zhuǎn)換成R進制相對比較復雜些,前面將R進制轉(zhuǎn)換成十進制時采用的乘以基數(shù)的位權次方求和法,那么將十進制轉(zhuǎn)換成R進制則是一個逆過程,整數(shù)部分采用除以基數(shù)求余法,余數(shù)由低向高;小數(shù)部分采用乘R取整法,由高到低。具體步驟如下:步驟(整數(shù)部分):(1)將十進制數(shù)除r,保存余數(shù)。(2)如果商為0,則進行第三步,否則,用商代替原十進制數(shù),重復第1步。(3)將所有的余數(shù)找出,最后得到的余數(shù)作為最高位,最先得出的余數(shù)作為最低位,由各余數(shù)依次排列而成的新的數(shù)據(jù)就是轉(zhuǎn)換成r進制的結果。步驟(小數(shù)部分):(1)、將十進制小數(shù)部分乘以r,保存此時的整數(shù)(包含整數(shù)0)(2)、若積為一個整數(shù)或者所得的結果達到了題中要求的精度則進入第三步,否則重復第一步(3)、將所有的整數(shù)找出,最先得到的整數(shù)作為最高位,最后得出的整數(shù)作為最低位,由各整數(shù)依次排列而成的新的數(shù)據(jù)就是轉(zhuǎn)換成R進制的結果。例3、將(47.3215)10轉(zhuǎn)換為二進制數(shù)。

①整數(shù)部分轉(zhuǎn)換將整數(shù)49“除二取余”法,由于后得到的“余”的權大于先得到的。因此,取余數(shù)的過程與計算過程相反,要從下向上取。如下圖5-2所示。

②小數(shù)部分轉(zhuǎn)換:

小數(shù)部分0.3125用“乘二取整”法,書寫順序:第一次乘以2所得整數(shù)是最高位

(即從上往下書寫)小數(shù)部分的轉(zhuǎn)換結果,如圖5-3所示。綜合上面兩步,最后得到的結果為:(47.3125)10=(101111.0101)2圖5-2整數(shù)部分轉(zhuǎn)換示意圖圖5-3小數(shù)部分轉(zhuǎn)換示意圖第二種轉(zhuǎn)換方式、計算器轉(zhuǎn)換法采用這種轉(zhuǎn)換方式比較直觀,通過Windows操作系統(tǒng)內(nèi)部提供的計算器進行轉(zhuǎn)換。點擊開始菜單,“程序→附件→計算器”即可彈出如下圖5-4所示的窗口。例4、采用計算器的轉(zhuǎn)換方式將十六進制(2AF5)16換算成10進制:①、打開計算器軟件,進入科學型窗口,如圖5-4所示;②、點擊圖中的“十六進制”,從鍵盤輸入“2AF5”,如下圖5-6所示。圖5-6進制轉(zhuǎn)換前的數(shù)據(jù)輸入③數(shù)據(jù)輸入完畢后,點擊“十進制”即可得出答案,如圖5-7所示。圖5-7轉(zhuǎn)換后的數(shù)據(jù)結果圖5.3計算機中信息的表示及存儲計算機內(nèi)部采用二進制的方式計數(shù),一個二進制位稱一個比特(bit)。不論是數(shù)值數(shù)據(jù)還是文字、圖形等,在計算機內(nèi)部都采用了一種編碼標準。通過編碼標準可以把它轉(zhuǎn)換成二進制數(shù)來進行處理,計算機將這些信息處理完畢再轉(zhuǎn)換成可視的信息顯示出來。計算機中數(shù)據(jù)為什么以二進制表示呢?可行性:二進制數(shù)只有0,1兩個數(shù)碼,采用電子器件很容易實現(xiàn)。可靠性:二進制的0,1兩種狀態(tài),在傳輸和處理時不容易出錯。簡易性:使計算機的運算器結構大大簡化,控制簡單。

邏輯性:二進制的0,1兩種狀態(tài),代表邏輯運算“假”和“真”兩種值。5.3.1英文文字符號編碼英文中的字母、符號通常采用ASCII(AmericanStandardCodeofInformationInterchange)碼,它原來是美國標準信息交換碼,1967年被定為國際標準碼。ASCII碼表見附錄。一個ASCII碼由8位二進制數(shù)組成,占據(jù)一個字節(jié)空間。其中最高位為奇偶校驗位,用于在傳輸過程檢驗數(shù)據(jù)的正確性;其余7位二進制數(shù)表示一個字符,共有27=128種組合。例如:回車的ASCII碼為0001101(13),空格的ASCII碼為0100000(32),“0”的ASCII碼為0110000(48),“A”的ASCII碼為1000001(65),“a”的ASCII碼為1100001(97)等。通常編碼打字符號代碼分布具有以下特點:1.空格符(SP)的代碼最小、刪除符(Del)的代碼最大。2.數(shù)字代碼小于字母代碼。3.大寫字母小于小寫字母,26個字母中A最小,Z最大。例:已知英文字母A的ASCII碼值為65,那么英文字母I的ASCII碼值是多少?分析:ASCII碼表中A和I相差8,已知A的ASCII碼是65,那么I的ASCII碼就是65+8=73;5.3.2中文文字編碼為了表示和交換漢字信息,1981年我國國家標準局制定了《信息交換用漢字編碼字符集》,代號為GB2312-80,簡稱國標碼。國標碼共對7445個漢字和符號進行了編碼,并根據(jù)使用的頻率將6763個漢字分為兩個等級:一級漢字包括3755個常用漢字,按漢語拼音順序排列;二級漢字包括3008個次常用漢字,按偏旁部首及筆畫順序排列。

GB2312-80國標碼的編碼原則是:一個漢字用兩個字節(jié)表示,分別稱為前字節(jié)和后字節(jié),每字節(jié)用低7位二進制碼,共計14位二進制碼,能組成214=16384個不同的代碼,并將代碼分成94區(qū),每個區(qū)94個漢字或符號。對每個漢字符號,前字節(jié)編碼稱為區(qū)碼,后字節(jié)編碼稱為位碼,即區(qū)位碼。在區(qū)位碼中01區(qū)到15區(qū)是非漢字圖形符號,16區(qū)到55區(qū)是一級漢字,56區(qū)到87區(qū)是二級漢字,87區(qū)以后空閑,可以存放標準庫中沒有的生偏漢字。

漢字的輸入?yún)^(qū)位碼和其國標碼之間的轉(zhuǎn)換方法為:將一個漢字的十進制區(qū)號和十進制位號分別轉(zhuǎn)換成十六進制;然后再分別加上20H,就成為此漢字的國標碼。例:已知漢字“家”的區(qū)位碼是2850,其國標碼是:3C52H本題中“家”的區(qū)位碼:285

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論