java-流的使用完結與異常處理機制(詳解)
1.1 java.io.objectInputStream 對象輸入流:用于將一組字節(jié)(通過對象輸出流寫出對象而轉換的一組字節(jié))讀取并轉換為對應的對象。對象輸出流將對象寫出時轉換為一組字節(jié)的過程,稱為:對象序列化對象輸入流將這組字節(jié)讀取并還原會對象的過程,稱為:對象反序列化
1.2 java.io.Serializable Serializable序列化接口
當一個類實現(xiàn)了Serializable接口后,應當在當前類中添加一個常量: 序列化版本號serialVersionUID
序列化版本號若不指定,那么編譯器會在編譯后的class文件中默認添加一個,而值則是根據(jù)當前類結構生成,但這有一個問題,若當前類的結構發(fā)生了變化,那么版本號會發(fā)生變化,所以建議自行制定版本號 版本號影響對象反序列化的結果:當對象輸入流讀取一個對象并嘗試進行反序列化時會檢測該對象的版本號與其所屬類現(xiàn)有版本號是否一致,一致則反序列化成功,不一致則反序列化失敗版本號一致的情況下,若待反序列化的對象與當前類現(xiàn)有結構不一致是,則采取兼容模式,即:該對象的屬相現(xiàn)有類依然有的則還原,沒有的則被忽略。
transient--關鍵字:該關鍵字用來修飾屬性,那么當該對象進行序列化時,這個屬性的值會被忽略,從而達到對象“瘦身”的效果
1.3 java.io.FileOutputStream;Java根據(jù)流讀寫數(shù)據(jù)的單位劃分為:字節(jié)流,字符流 字節(jié)流以字節(jié)為單位讀寫數(shù)據(jù)字符流以字符(unicode)為單位讀寫數(shù)據(jù),但是底層本質上還是讀寫字節(jié),只是字節(jié)與字符的轉換工作有字符流完成Weiter與Reader是所有字符流的父類,他們是一對抽象類,規(guī)定了所有字符流都要具備的讀寫字符方法。轉換流OutoutStreamWriter與InputStreamReader是字符流的一對常見實現(xiàn)類
OutputStreamWriter的構造方法支持第二個參數(shù),可以指定字符集,這樣通過該流寫出的字符都會按照指定的字符集轉換,若不指定第二個參數(shù)則安裝系統(tǒng)默認字符集轉換
1.4 java.io.PrintWriter;緩沖字符流:緩沖字符流內置緩沖區(qū),可以提高讀寫字符效率,并且緩沖字符流的特點可以按行讀寫字符串。
java.io.BufferedWriter
java.io.BufferefReader
java.io.printWriter是常用的緩沖字符輸出流,并且還提供了支佛那個行刷新功能,由于創(chuàng)建PrintWriter時其內部總是嵌套BufferedWriter所以實際的緩沖操作是由BufferefWriter實現(xiàn)
printWriter(pw)支持直接對文件操作的構造方法
printwriter(String path,String snc)
printwriter(File file,String snc)
csn:charset name 字符集名稱
PrintWriter在流鏈接中的構造方法:
PrintWriter(OutputStream out)
PrintWriter(Writer out)
使用上訴構造方法是,有一個對應的重載構造方法要求傳入第二個參數(shù),該參數(shù)為boolean值若該值為true,則pw具有自動行刷新功能,即:每當使用PW。println()寫出內容后都會自動進行
flush操作
PrintWriter(OutputStream out,boolean autoflush)
PrintWriter(Writer out,boolean autoflush)
1.5 java.io.BufferedReader;緩沖字節(jié)輸入流 可以按行讀取字符串
BufferedReader提供方法:
String readLine()連續(xù)讀取若干字符,知道讀取了換行符為止,將之前的所有字符以一個字符串形式返回。注意,返回的字符串中是不包含最后的換行的,若返回為null,則表示末尾.
2.1 異常捕獲機制中的try-catch
catch可以定義多個,針對try代碼塊中可能出現(xiàn)的異常有不同的處理方式時,需要單獨捕獲這些異常并編寫解決手段代碼但是應當養(yǎng)成一個習慣,就是在最后捕獲一個Exceotion,這樣會避免因拋出一個未捕獲的異常導致程序出現(xiàn)中斷的情況,當捕獲的異常之間存在繼承關系時,需要將子類異常定義在上面捕獲,后定義父類型異常。
異常捕獲機制中的finally;finally塊只能定義在異常捕獲機制的最后,即:try之后或者一個catch之后。finally塊可以保證無論try語句塊中的代碼是否拋出異常,finally塊中的代碼都必將執(zhí)行。所以通常會將無關異常都要執(zhí)行的代碼放入finally塊中確保執(zhí)行,比如IO操作中的關閉流操作。
注意:finalize;當一個對象即將被GC釋放前,GC會調用該對象的finalize方法,調用后該對象即被釋放。finalize方法是Object定義的方法
我是初學者,如有更新不好的,歡迎這位大神指出,謝謝大家!
以上這篇java-流的使用完結與異常處理機制(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
使用Idea或Datagrip導入excel數(shù)據(jù)的方法
這篇文章主要介紹了使用Idea或Datagrip導入excel數(shù)據(jù)的方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11
SpringBoot中@PostConstruct 注解的實現(xiàn)
在Spring Boot框架中,?@PostConstruct是一個非常有用的注解,它用于在依賴注入完成后執(zhí)行初始化方法,本文將介紹?@PostConstruct的基本概念、使用場景以及提供詳細的代碼示例,感興趣的可以了解一下2024-09-09
SpringSecurity詳解整合JWT實現(xiàn)全過程
JWT作為一個開放的標準(?RFC?7519?),定義了一種簡潔的,自包含的方法用于通信雙方之間以Json對象的形式安全的傳遞信息。接下來通過本文給大家介紹springSecurity+jwt實現(xiàn)互踢功能,需要的朋友可以參考下2022-07-07
Spring使用AspectJ的注解式實現(xiàn)AOP面向切面編程
這篇文章主要介紹了Spring使用AspectJ的注解式實現(xiàn)AOP面向切面編程的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06
SpringBoot?整合mapstruct的實現(xiàn)步驟
這篇文章主要介紹了SpringBoot整合mapstruct,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11
SpringBoot整合Redis將對象寫入redis的實現(xiàn)
本文主要介紹了SpringBoot整合Redis將對象寫入redis的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-06-06

