JavaIO字符操作和對(duì)象操作示例詳解
字符操作
編碼與解碼
編碼就是把字符轉(zhuǎn)換為字節(jié),而解碼是把字節(jié)重新組合成字符。
如果編碼和解碼過程使用不同的編碼方式那么就出現(xiàn)了亂碼。
- GBK 編碼中,中文字符占 2 個(gè)字節(jié),英文字符占 1 個(gè)字節(jié);
- UTF-8 編碼中,中文字符占 3 個(gè)字節(jié),英文字符占 1 個(gè)字節(jié);
- UTF-16be 編碼中,中文字符和英文字符都占 2 個(gè)字節(jié)。
UTF-16be 中的 be 指的是 Big Endian,也就是大端。相應(yīng)地也有 UTF-16le,le 指的是 Little Endian,也就是小端。
Java 的內(nèi)存編碼使用雙字節(jié)編碼 UTF-16be,這不是指 Java 只支持這一種編碼方式,而是說 char 這種類型使用 UTF-16be 進(jìn)行編碼。char 類型占 16 位,也就是兩個(gè)字節(jié),Java 使用這種雙字節(jié)編碼是為了讓一個(gè)中文或者一個(gè)英文都能使用一個(gè) char 來存儲(chǔ)。
String 的編碼方式
String 可以看成一個(gè)字符序列,可以指定一個(gè)編碼方式將它編碼為字節(jié)序列,也可以指定一個(gè)編碼方式將一個(gè)字節(jié)序列解碼為 String。
String str1 = "中文"; byte[] bytes = str1.getBytes("UTF-8"); String str2 = new String(bytes, "UTF-8"); System.out.println(str2);
在調(diào)用無參數(shù) getBytes() 方法時(shí),默認(rèn)的編碼方式不是 UTF-16be。雙字節(jié)編碼的好處是可以使用一個(gè) char 存儲(chǔ)中文和英文,而將 String 轉(zhuǎn)為 bytes[] 字節(jié)數(shù)組就不再需要這個(gè)好處,因此也就不再需要雙字節(jié)編碼。getBytes() 的默認(rèn)編碼方式與平臺(tái)有關(guān),一般為 UTF-8。
byte[] bytes = str1.getBytes();
Reader 與 Writer
不管是磁盤還是網(wǎng)絡(luò)傳輸,最小的存儲(chǔ)單元都是字節(jié),而不是字符。但是在程序中操作的通常是字符形式的數(shù)據(jù),因此需要提供對(duì)字符進(jìn)行操作的方法。
- InputStreamReader 實(shí)現(xiàn)從字節(jié)流解碼成字符流;
- OutputStreamWriter 實(shí)現(xiàn)字符流編碼成為字節(jié)流。
實(shí)現(xiàn)逐行輸出文本文件的內(nèi)容
public static void readFileContent(String filePath) throws IOException { FileReader fileReader = new FileReader(filePath); BufferedReader bufferedReader = new BufferedReader(fileReader); String line; while ((line = bufferedReader.readLine()) != null) { System.out.println(line); } // 裝飾者模式使得 BufferedReader 組合了一個(gè) Reader 對(duì)象 // 在調(diào)用 BufferedReader 的 close() 方法時(shí)會(huì)去調(diào)用 Reader 的 close() 方法 // 因此只要一個(gè) close() 調(diào)用即可 bufferedReader.close(); }
對(duì)象操作
序列化
序列化就是將一個(gè)對(duì)象轉(zhuǎn)換成字節(jié)序列,方便存儲(chǔ)和傳輸。
- 序列化:ObjectOutputStream.writeObject()
- 反序列化:ObjectInputStream.readObject()
不會(huì)對(duì)靜態(tài)變量進(jìn)行序列化,因?yàn)樾蛄谢皇潜4鎸?duì)象的狀態(tài),靜態(tài)變量屬于類的狀態(tài)。
Serializable
序列化的類需要實(shí)現(xiàn) Serializable 接口,它只是一個(gè)標(biāo)準(zhǔn),沒有任何方法需要實(shí)現(xiàn),但是如果不去實(shí)現(xiàn)它的話而進(jìn)行序列化,會(huì)拋出異常。
public static void main(String[] args) throws IOException, ClassNotFoundException { A a1 = new A(123, "abc"); String objectFile = "file/a1"; ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream(objectFile)); objectOutputStream.writeObject(a1); objectOutputStream.close(); ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream(objectFile)); A a2 = (A) objectInputStream.readObject(); objectInputStream.close(); System.out.println(a2); } private static class A implements Serializable { private int x; private String y; A(int x, String y) { this.x = x; this.y = y; } @Override public String toString() { return "x = " + x + " " + "y = " + y; } }
transient
transient 關(guān)鍵字可以使一些屬性不會(huì)被序列化。
ArrayList 中存儲(chǔ)數(shù)據(jù)的數(shù)組 elementData 是用 transient 修飾的,因?yàn)檫@個(gè)數(shù)組是動(dòng)態(tài)擴(kuò)展的,并不是所有的空間都被使用,因此就不需要所有的內(nèi)容都被序列化。通過重寫序列化和反序列化方法,使得可以只序列化數(shù)組中有內(nèi)容的那部分?jǐn)?shù)據(jù)。
private transient Object[] elementData;
以上就是JavaIO字符操作和對(duì)象操作示例詳解的詳細(xì)內(nèi)容,更多關(guān)于JavaIO字符操作對(duì)象操作的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Java?IO篇之Reactor?網(wǎng)絡(luò)模型的概念
- Java網(wǎng)絡(luò)編程之IO模型阻塞與非阻塞簡(jiǎn)要分析
- java中Pulsar?InterruptedException?異常
- flutter升級(jí)3.7.3報(bào)錯(cuò)Unable?to?find?bundled?Java?version解決
- Java中StringUtils與CollectionUtils和ObjectUtil概念講解
- Java線程池隊(duì)列PriorityBlockingQueue和SynchronousQueue詳解
- Java?IO網(wǎng)絡(luò)模型實(shí)現(xiàn)解析
相關(guān)文章
SpringCloud Zuul網(wǎng)關(guān)功能實(shí)現(xiàn)解析
這篇文章主要介紹了SpringCloud Zuul網(wǎng)關(guān)功能實(shí)現(xiàn)解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03Java之map的常見用法講解與五種循環(huán)遍歷實(shí)例代碼理解
map是一組鍵值對(duì)的組合,通俗理解類似一種特殊的數(shù)組,a[key]=val,只不過數(shù)組元素的下標(biāo)是任意一種類型,而且數(shù)組的元素的值也是任意一種類型。有點(diǎn)類似python中的字典。通過"鍵"來取值,類似生活中的字典,已知索引,來查看對(duì)應(yīng)的信息2021-09-09微信公眾帳號(hào)開發(fā)-自定義菜單的創(chuàng)建及菜單事件響應(yīng)的實(shí)例
本篇文章主要介紹了微信公眾帳號(hào)開發(fā)-自定義菜單的創(chuàng)建及菜單事件響應(yīng)的實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-12-12SpringCloud實(shí)現(xiàn)基于RabbitMQ消息隊(duì)列的詳細(xì)步驟
在Spring Cloud框架中,我們可以利用RabbitMQ實(shí)現(xiàn)強(qiáng)大而可靠的消息隊(duì)列系統(tǒng),本篇將詳細(xì)介紹如何在Spring Cloud項(xiàng)目中集成RabbitMQ,并創(chuàng)建一個(gè)簡(jiǎn)單的消息隊(duì)列,感興趣的朋友一起看看吧2024-03-03springboot實(shí)現(xiàn)獲取當(dāng)前服務(wù)器IP及當(dāng)前項(xiàng)目使用的端口號(hào)Port
這篇文章主要介紹了springboot實(shí)現(xiàn)獲取當(dāng)前服務(wù)器IP及當(dāng)前項(xiàng)目使用的端口號(hào)Port方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12Java編程實(shí)現(xiàn)從給定范圍內(nèi)隨機(jī)N個(gè)不重復(fù)數(shù)生成隨機(jī)數(shù)的方法小結(jié)
這篇文章主要介紹了Java編程實(shí)現(xiàn)從給定范圍內(nèi)隨機(jī)N個(gè)不重復(fù)數(shù)生成隨機(jī)數(shù)的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了java根據(jù)指定范圍生成不重復(fù)隨機(jī)數(shù)的相關(guān)操作技巧,需要的朋友可以參考下2017-04-04強(qiáng)烈推薦IDEA提高開發(fā)效率的必備插件
這篇文章主要介紹了強(qiáng)烈推薦IDEA提高開發(fā)效率的必備插件,文中有非常詳細(xì)的圖文示例,對(duì)想要提高企業(yè)開發(fā)效率的小伙伴們有非常好的幫助,需要的朋友可以參考下2021-04-04