IO流 p5 節點流和處理流

来源:https://www.cnblogs.com/zh-Note/archive/2023/06/05/17455295.html
-Advertisement-
Play Games

# 節點流 和 處理流 [TOC] - **節點流和處理流一覽圖:** ![img](https://img-blog.csdnimg.cn/img_convert/8ca5f4f2e434e5c05149bcb7ebc281a8.png) ​ 【圖片來源】http://t.csdn.cn/d52a ...


節點流 和 處理流

目錄

  • 節點流和處理流一覽圖:

img

​ 【圖片來源】http://t.csdn.cn/d52a1

一、基本介紹

  1. 節點流:節點流可以從一個特定的數據源讀寫數據,如FIleReader、FileWriter

  2. 處理流:處理流(也叫包裝流)是“連接”在已存在的流(節點流或處理流)之上,為程式提供更為強大的讀寫功能,也更加靈活,如BufferedReader、BufferedWriter。使用了修飾器設計模式。就是面向對象的封裝思想,消除不同數據之間的差異性,僅對外暴露介面。

二、節點流 和 處理流 的區別和聯繫

  1. 節點流是底層流/低級流,直接跟數據源相接。

  2. 處理流(包裝流)包裝結點流,即可以消除不同節點的實現差異,也可以提供更方便的方法來完成輸入輸出。

  3. 處理流(也叫包裝流)對節點流進行包裝,使用了修飾器設計模式,不會直接與數據源相連

    /**
     * @author
     * @version 1.0
     * 模擬修飾器設計模式
     */
    public class Test_ {
        public static void main(String[] args) {
            BufferedReader_ bufferedReader_ = new BufferedReader_(new FileReader_());
            bufferedReader_.readFiles(10);
    
            //希望通過BufferedReader_ 多次讀取字元串
            BufferedReader_ bufferedReader_1 = new BufferedReader_(new StringReader_());
            bufferedReader_1.readStrings(5);
        }
    }
    abstract class Reader_ {
        public void readFile_(){}
        public void readString_(){}
    
        //在Reader_抽象類,使用read方法統一管理
    //    public abstract void read();
        //後面在調用時就,利於對象動態綁定機制,綁定到對應的實現子類即可。
    }
    
    // 模擬節點流
    class FileReader_ extends Reader_{
        public void readFile_(){
            System.out.println("對文件進行讀取……");
        }
    //    public void read(){
    //        System.out.println("對文件進行讀取……");
    //    }
    }
    
    //模擬節點流
    class StringReader_ extends Reader_{
        public void readString_(){
            System.out.println("讀取字元串……");
        }
    //    public void read(){
    //        System.out.println("讀取字元串……");
    //    }
    }
    
    
    //模擬處理流/包裝流
    class BufferedReader_ extends Reader_{
        //註意裝飾器模式中,裝飾類和被裝飾類(約定俗成,而非必須)繼承自同一個父類。
        private Reader_ reader_;//屬性是 Reader_
    
        //接收Reader_子類對象
        public BufferedReader_(Reader_ reader_) {
            this.reader_ = reader_;
        }
    
        public void readFile(){
            reader_.readFile_();
        }
    
        //讓方法更靈活,多次讀取文件,或者加緩衝char[]....
        public void readFiles(int num){
            for (int i = 0; i < num; i++) {
                reader_.readFile_();
            }
        }
    
        //擴展 readString,批量處理字元串數據
        public void readStrings(int num){
            for (int i = 0; i < num; i++) {
                reader_.readString_();
            }
        }
    }
    
    

三、處理流的功能主要體現在以下兩個方面:

  1. 性能的提高:主要以增加緩衝的方式來提高輸入和輸出的效率。
  2. 操作的便捷:處理流提供了一系列便捷的方法來一次輸入輸出大批量的數據就,使用更加靈活方便。

四、處理流 — BufferedReader和BufferedWriter

  • BufferedReader 和 BufferedWriter屬於字元流,是按照字元來讀取數據的;
  • 關閉處理流,只需關閉外層流即可,關閉外層流(包裝流)時會自動關閉包裝的節點流;
  • BufferedReader 和 BufferedWriter 是安裝字元操作,不要去操作二進位文件,可能造成文件損壞;
  1. BufferedReader

    • 構造方法摘要

      Constructor and Description
      BufferedReader(Reader in)創建使用預設大小的輸入緩衝區的緩衝字元輸入流。
      BufferedReader(Reader in, int sz)創建使用指定大小的輸入緩衝區的緩衝字元輸入流。
    • 方法摘要

      Modifier and Type Method and Description
      void close()關閉流並釋放與之相關聯的任何系統資源。
      Stream<String> lines()返回一個 Stream ,其元素是從這個 BufferedReader讀取的行。
      void mark(int readAheadLimit)標記流中的當前位置。
      boolean markSupported()告訴這個流是否支持mark()操作。
      int read()讀一個字元
      int read(char[] cbuf, int off, int len)將字元讀入數組的一部分。
      String readLine()讀一行文字。
      boolean ready()告訴這個流是否準備好被讀取。
      void reset()將流重置為最近的標記。
      long skip(long n)跳過字元
    • 代碼演示:

      import java.io.BufferedReader;
      import java.io.FileNotFoundException;
      import java.io.FileReader;
      import java.io.IOException;
      
      /**
       * @author
       * @version 1.0
       * 演示BufferedReader的使用
       */
      public class BufferedReader_ {
          public static void main(String[] args) throws IOException {
              String filePath = "e:\\a.java";
              //創建BufferedReader對象
              BufferedReader bufferedReader = new BufferedReader(new FileReader(filePath));
              //讀取
              String line;//按行讀取,效率高
              //1. bufferedReader.readLine() 是按行讀取文件
              //2. 當返回null時,表示文件讀取完畢
              while((line = bufferedReader.readLine()) != null){
                  System.out.println(line);
              }
      
              //關閉流
              //這裡註意,只需關閉 BufferedReader(外層流),因為底層會自動的去關閉節點流 FileReader
              /**
               * public void close() throws IOException {
               *         synchronized (lock) {
               *             if (in == null)
               *                 return;
               *             try {
               *                 in.close();
               *             } finally {
               *                 in = null;// in 就是我們傳入的 new FileReader(filePath),關閉了
               *                 cb = null;
               *             }
               *         }
               *     }
               */
              bufferedReader.close();
          }
      }
      
      
    1. BufferedWriter

      • 構造方法摘要

        Constructor and Description
        BufferedWriter(Writer out)創建使用預設大小的輸出緩衝區的緩衝字元輸出流。
        BufferedWriter(Writer out, int sz)創建一個新的緩衝字元輸出流,使用給定大小的輸出緩衝區。
      • 方法摘要

        Modifier and Type Method and Description
        void close()關閉流,先刷新。
        void flush()刷新流。
        void newLine()寫一行行分隔符。
        void write(char[] cbuf, int off, int len)寫入字元數組的一部分。
        void write(int c)寫一個字元
        void write(String s, int off, int len)寫一個字元串的一部分。
      • 代碼演示:

        import java.io.BufferedWriter;
        import java.io.FileWriter;
        import java.io.IOException;
        
        public class BufferedWriter_ {
            public static void main(String[] args) throws IOException {
                String filePath = "e:\\BufferedWriter_.java";
                BufferedWriter bufferedWriter = new BufferedWriter(new FileWriter(filePath, true));
                bufferedWriter.write("hello, 你好");
                //插入一個和系統 相關的換行
                bufferedWriter.newLine();
        //        bufferedWriter.write("\r\n");
                bufferedWriter.write("hello, 你好");
                //關閉外層流即可,傳入的節點流會自動關閉
                bufferedWriter.close();
        
            }
        }
        
        

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ## 前言 C語言中的迴圈結構時,`for`迴圈是最常用的一種。它允許重覆執行一段代碼,直到滿足特定條件為止。 本文將詳細介紹`for`迴圈的用法,並提供相關的可編譯運行的C代碼示例。 ## 一、人物簡介 - 第一位閃亮登場,有請今後會一直教我們C語言的老師 —— 自在。 ![img](https: ...
  • # 第一章:瞭解(chapter) ## 複習方法: 找到視頻 每個章節 結合筆記。 https://www.bilibili.com/video/BV1fh411y7R8?p=266&spm_id_from=pageDriver&vd_source=5c60787a1cdddc0e6d23d53b ...
  • # 演算法 in Go:Binary Search(二分查找) ## Binary Search(二分查找) ### Binary Search(二分查找) - 猜數 - 1、2、3、4、5、6、7、8 - 排好序一個集合,先從中間開始猜,根據提示就可以排除一半,在剩餘的一半里,再從中間開始猜,依此類 ...
  • # SpringCloud Sleuth+Zipkin-鏈路追蹤 官網:[spring-cloud/spring-cloud-sleuth: Distributed tracing for spring cloud (github.com)](https://github.com/spring-cl ...
  • # 對象流ObjectInputStream和ObjectOutputStream ## 引言 - 看一個需求 1. 將int num=100這個 int 數據保存到文件中,註意不是 100 數字,而是 int 100,並且,能夠從文件中直接恢復 int 100; 2. 將Dog dog = new ...
  • 某日二師兄參加XXX科技公司的C++工程師開發崗位6面: > 面試官: 如何在堆上申請一塊記憶體? > > 二師兄:常用的方法有malloc,new等。 > > 面試官:兩者有什麼區別? > > 二師兄:malloc是向操作系統申請一塊記憶體,這塊記憶體沒有經過初始化,通常需要使用memset手動初始化。 ...
  • # BufferedInputStream 和 BufferedOutputStream - BufferedInputStream ![](https://img2023.cnblogs.com/blog/3008601/202306/3008601-20230604103033021-44120 ...
  • 大家好,我3y啊。由於去重邏輯重構了幾次,好多股東直呼看不懂,於是我今天再安排一波對代碼的解析吧。`austin`支持兩種去重的類型:**N分鐘相同內容達到N次**去重和**一天內N次相同渠道頻次**去重。 > **Java開源項目消息推送平臺🔥推送下發【郵件】【簡訊】【微信服務號】【微信小程式】 ...
一周排行
    -Advertisement-
    Play Games
  • 1. 說明 /* Performs operations on System.String instances that contain file or directory path information. These operations are performed in a cross-pla ...
  • 視頻地址:【WebApi+Vue3從0到1搭建《許可權管理系統》系列視頻:搭建JWT系統鑒權-嗶哩嗶哩】 https://b23.tv/R6cOcDO qq群:801913255 一、在appsettings.json中設置鑒權屬性 /*jwt鑒權*/ "JwtSetting": { "Issuer" ...
  • 引言 集成測試可在包含應用支持基礎結構(如資料庫、文件系統和網路)的級別上確保應用組件功能正常。 ASP.NET Core 通過將單元測試框架與測試 Web 主機和記憶體中測試伺服器結合使用來支持集成測試。 簡介 集成測試與單元測試相比,能夠在更廣泛的級別上評估應用的組件,確認多個組件一起工作以生成預 ...
  • 在.NET Emit編程中,我們探討了運算操作指令的重要性和應用。這些指令包括各種數學運算、位操作和比較操作,能夠在動態生成的代碼中實現對數據的處理和操作。通過這些指令,開發人員可以靈活地進行算術運算、邏輯運算和比較操作,從而實現各種複雜的演算法和邏輯......本篇之後,將進入第七部分:實戰項目 ...
  • 前言 多表頭表格是一個常見的業務需求,然而WPF中卻沒有預設實現這個功能,得益於WPF強大的控制項模板設計,我們可以通過修改控制項模板的方式自己實現它。 一、需求分析 下圖為一個典型的統計表格,統計1-12月的數據。 此時我們有一個需求,需要將月份按季度劃分,以便能夠直觀地看到季度統計數據,以下為該需求 ...
  • 如何將 ASP.NET Core MVC 項目的視圖分離到另一個項目 在當下這個年代 SPA 已是主流,人們早已忘記了 MVC 以及 Razor 的故事。但是在某些場景下 SSR 還是有意想不到效果。比如某些靜態頁面,比如追求首屏載入速度的時候。最近在項目中回歸傳統效果還是不錯。 有的時候我們希望將 ...
  • System.AggregateException: 發生一個或多個錯誤。 > Microsoft.WebTools.Shared.Exceptions.WebToolsException: 生成失敗。檢查輸出視窗瞭解更多詳細信息。 內部異常堆棧跟蹤的結尾 > (內部異常 #0) Microsoft ...
  • 引言 在上一章節我們實戰了在Asp.Net Core中的項目實戰,這一章節講解一下如何測試Asp.Net Core的中間件。 TestServer 還記得我們在集成測試中提供的TestServer嗎? TestServer 是由 Microsoft.AspNetCore.TestHost 包提供的。 ...
  • 在發現結果為真的WHEN子句時,CASE表達式的真假值判斷會終止,剩餘的WHEN子句會被忽略: CASE WHEN col_1 IN ('a', 'b') THEN '第一' WHEN col_1 IN ('a') THEN '第二' ELSE '其他' END 註意: 統一各分支返回的數據類型. ...
  • 在C#編程世界中,語法的精妙之處往往體現在那些看似微小卻極具影響力的符號與結構之中。其中,“_ =” 這一組合突然出現還真不知道什麼意思。本文將深入剖析“_ =” 的含義、工作原理及其在實際編程中的廣泛應用,揭示其作為C#語法奇兵的重要角色。 一、下劃線 _:神秘的棄元符號 下劃線 _ 在C#中並非 ...