成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

文本文件和二進制文件的區(qū)別有哪些

這篇文章主要介紹文本文件和二進制文件的區(qū)別有哪些,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、微信平臺小程序開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了淮安區(qū)免費建站歡迎大家使用!

文本文件和二進制文件區(qū)別:1、文本文件是基于字符編碼的文件,常見的編碼有ASCII編碼,UNICODE編碼等;2、二進制文件是基于值編碼的文件

文本文件和二進制文件區(qū)別:

一、文本文件與二進制文件的定義

大家都知道計算機的存儲在物理上是二進制的,所以文本文件與二進制文件的區(qū)別并不是物理上的,而是邏輯上的。這兩者只是在編碼層次上有差異。

簡單來說,文本文件是基于字符編碼的文件,常見的編碼有ASCII編碼,UNICODE編碼等等。二進制文件是基于值編碼的文件,你可以根據(jù)具體應(yīng)用,指定某個值是什么意思(這樣一個過程,可以看作是自定義編碼)。

從上面可以看出文本文件基本上是定長編碼的,基于字符嘛,每個字符在具體編碼中是固定的,ASCII碼是8個比特的編碼,UNICODE一般占16個比特。而二進制文件可看成是變長編碼的,因為是值編碼嘛,多少個比特代表一個值,完全由你決定。大家可能對BMP文件比較熟悉,就拿它舉例子吧,其頭部是較為固定長度的文件頭信息,前2字節(jié)用來記錄文件為BMP格式,接下來的8個字節(jié)用來記錄文件長度,再接下來的4字節(jié)用來記錄bmp文件頭的長度。。。大家可以看出來了吧,其編碼是基于值的(不定長的,2、4、8字節(jié)長的值都有),所以BMP是二進制文件。

二、文本文件與二進制文件的存取

文本工具打開一個文件的過程是怎樣的呢?拿記事本來說,它首先讀取文件物理上所對應(yīng)的二進制比特流(前面已經(jīng)說了,存儲都是二進制的),然后按照你所選擇的解碼方式來解釋這個流,然后將解釋結(jié)果顯示出來。一般來說,你選取的解碼方式會是ASCII碼形式(ASCII碼的一個字符是8個比特),接下來,它8個比特8個比特地來解釋這個文件流。例如對于這么一個文件流"01000000_01000001_01000010_01000011"(下劃線'_',是我為了增強可讀性,而手動添加的),第一個8比特'01000000'按ASCII碼來解碼的話,所對應(yīng)的字符是字符'A',同理其它3個8比特可分別解碼為'BCD',即這個文件流可解釋成“ABCD”,然后記事本就將這個“ABCD”顯示在屏幕上。

事實上,世界上任何東西要與其他東西通信會話,都存在一個既定的協(xié)議,既定的編碼。人與人之間通過文字聯(lián)絡(luò),漢字“媽”代表生你的那個人,這就是一種既定的編碼。但注意到這樣一種情況,漢字“媽”在日本文字里有可能是你生下的那個人,所以當(dāng)一個中國人A與日本B之間用“媽”這個字進行交流,出現(xiàn)誤解就很正常的。用記事本打開二進制文件與上面的情況類似。記事本無論打開什么文件都按既定的字符編碼工作(如ASCII碼),所以當(dāng)他打開二進制文件時,出現(xiàn)亂碼也是很必然的一件事情了,解碼和譯碼不對應(yīng)嘛。例如文件流'00000000_00000000_00000000_00000001'可能在二進制文件中對應(yīng)的是一個四字節(jié)的整數(shù)int1,在記事本里解釋就變成了"NULL_NULL_NULL_SOH"這四個控制符。

文本文件的存儲與其讀取基本上是個逆過程,不再累述。而二進制文件的存取顯然與文本文件的存取差不多,只是編/解碼方式不同而已,也不再敘述。

三、文本文件與二進制文件的優(yōu)缺點

因為文本文件與二進制文件的區(qū)別僅僅是編碼上不同,所以他們的優(yōu)缺點就是編碼的優(yōu)缺點,這個找本編碼的書來看看就比較清楚了。一般認為,文本文件編碼基于字符定長,譯碼容易些;二進制文件編碼是變長的,所以它靈活,存儲利用率要高些,譯碼難一些(不同的二進制文件格式,有不同的譯碼方式)。關(guān)于空間利用率,想想看,二進制文件甚至可以用一個比特來代表一個意思(位操作),而文本文件任何一個意思至少是一個字符.

很多書上還認為,文本文件的可讀性要好些,存儲要花費轉(zhuǎn)換時間(讀寫要編譯碼),而二進制文件可讀性差,存儲不存在轉(zhuǎn)換時間(讀寫不要編解碼,直接寫值).這里的可讀性是從軟件使用者角度來說的,因為我們用通用的記事本工具就幾乎可以瀏覽所有文本文件,所以說文本文件可讀性好;而讀寫一個具體的二進制文件需要一個具體的文件解碼器,所以說二進制文件可讀性差,比如讀BMP文件,必須用讀圖軟件.而這里的存儲轉(zhuǎn)換時間應(yīng)該是從編程的角度來說的,因為有些操作系統(tǒng)如windows需要對回車換行符進行轉(zhuǎn)換(將'\n',換成'\r\n',所以文件讀寫時,操作系統(tǒng)需要一個一個字符的檢查當(dāng)前字符是不是'\n'或'\r\n').這個在存儲轉(zhuǎn)換在Linux操作系統(tǒng)中并不需要,當(dāng)然,當(dāng)在兩個不同的操作系統(tǒng)上共享文件時,這種存儲轉(zhuǎn)換又可能出來(如Linux系統(tǒng)和Windows系統(tǒng)共享文本文件)。關(guān)于這個轉(zhuǎn)換怎樣進行,我將在下一篇文章《Linux文本文件與Windows文本文件間的轉(zhuǎn)換》給出^_^

四、C的文本讀寫和二進制讀寫

應(yīng)該說C的文本讀寫與二進制的讀寫是一個編程層次上的問題,與具體的操作系統(tǒng)有關(guān),所以"用文本方式讀寫的文件一定是文本文件,用二進制讀寫的文件一定是二進制文件"這類觀點是錯誤的.下面的講述非明確指出操作系統(tǒng)類型,都暗指windows.C的文本方讀寫與二進制讀寫的差別僅僅體現(xiàn)在回車換行符的處理上.文本方式寫時,每遇到一個'\n'(0AH換行符),它將其換成'\r\n'(0D0AH,回車換行),然后再寫入文件;當(dāng)文本讀取時,它每遇到一個'\r\n'將其反變化為'\n',然后送到讀緩沖區(qū).正因為文本方式有'\n'--'\r\n'之間的轉(zhuǎn)換,其存在轉(zhuǎn)換耗時.二進制讀寫時,其不存在任何轉(zhuǎn)換,直接將寫緩沖區(qū)中數(shù)據(jù)寫入文件.

總地來說,從編程的角度來說,C中文本或二進制讀寫都是緩沖區(qū)與文件中二進制流的交互,只是文本讀寫時有回車換行的轉(zhuǎn)換.所以當(dāng)寫緩沖區(qū)中無換行符'\n'(0AH),文本寫與二進制寫的結(jié)果是一樣的,同理,當(dāng)文件中不存在'\r\n'(0DH0AH)時,文本讀與二進制讀的結(jié)果一樣.

以上是“文本文件和二進制文件的區(qū)別有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

分享名稱:文本文件和二進制文件的區(qū)別有哪些
文章鏈接:http://jinyejixie.com/article40/jojdeo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號、網(wǎng)站排名關(guān)鍵詞優(yōu)化、虛擬主機、微信小程序云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
疏附县| 远安县| 乐业县| 襄城县| 揭东县| 永新县| 绍兴县| 肇东市| 读书| 永州市| 镇雄县| 根河市| 阿合奇县| 元阳县| 客服| 永州市| 洱源县| 达拉特旗| 湄潭县| 洪洞县| 定陶县| 连州市| 左贡县| 石屏县| 双柏县| 易门县| 宜宾县| 白银市| 延川县| 镇巴县| 西平县| 淄博市| 万荣县| 吴忠市| 胶南市| 河间市| 犍为县| 穆棱市| 富平县| 抚远县| 永寿县|