Java - IO 記憶體流和列印流

来源:https://www.cnblogs.com/wangyuyang1016/archive/2019/07/12/11178592.html
-Advertisement-
Play Games

IO 記憶體流和列印流操作 字元編碼 電腦中所有的信息組成都是二進位數據,所有能夠描述的中文文字都是經過處理後的結果;所有的語言文字都會使用編碼來進行描述,例如:ASCII碼 常見編碼 GBK/GB2312: 中文的國標編碼 GBK包含有簡體中文與繁體中文兩種,而GB2312只包含簡體中文 ISO ...


IO 記憶體流和列印流操作

字元編碼

  • 電腦中所有的信息組成都是二進位數據,所有能夠描述的中文文字都是經過處理後的結果;所有的語言文字都會使用編碼來進行描述,例如:ASCII碼

常見編碼

GBK/GB2312:

  • 中文的國標編碼
  • GBK包含有簡體中文與繁體中文兩種,而GB2312只包含簡體中文

ISO-8859-1:

  • 國際編碼
  • 可以描述任何的文字信息

UNICODE:

  • 十六進位編碼
  • 任何文字信息都用十六進位表示,會導致無用數據過多

UTF-8:*

  • 融合ISO8859-1和UNICODE兩種編碼的特點

字元亂碼

本質:

  • 編碼與解碼的字元集不統一

列出系統的所有環境變數

public class TestDemo {
    public static void main(String [] args) throws IOException {
        System.getProperties().list(System.out);
    }
}
  • 輸出結果
file.encoding=UTF-8

代表系統環境預設的字元集編碼為:UTF-8

public class TestDemo {
    public static void main(String [] args) throws IOException {
        File file = new File("F:" + File.separator + 
                "demo" + File.separator +
                "demo.txt");
        OutputStream out = new FileOutputStream(file);
        out.write("華為".getBytes());// getBytes() > 無轉碼
        out.close();
    }
}

上述是以預設的系統編碼方式進行輸出

華為

可以看出來,利用系統預設的編碼方式(不轉碼)編碼輸出,在用系統的編碼方式解碼,不會出現亂碼現象

public class TestDemo {
    public static void main(String [] args) throws IOException {
        File file = new File("F:" + File.separator + 
                "demo" + File.separator +
                "demo.txt");
        OutputStream out = new FileOutputStream(file);
        out.write("華為".getBytes("ISO8859-1"));// getBytes() > 無轉碼
        out.close();
    }
}

我們利用getBytes()方法將進行轉碼為ISO8859-1編碼方式輸出

??

由結果看出,系統使用GB2312進行解碼,而文件是使用ISO8859-1進行編碼,編碼和解碼的字元集不同由此導致了 亂碼現象 的出現

記憶體操作流

  • 在不產生新文件的情況下;利用記憶體流來實現輸入與輸出的操作

位元組記憶體流:

public class ByteArrayInputStream
extends InputStream
public class ByteArrayOutputStream
extends OutputStream

ByteArrayInputStream

  • 構造方法
public ByteArrayInputStream(byte [] buf)

將要操作的數據設置到記憶體輸入流

ByteArrayOutputStream

  • 構造方法
public ByteArrayOutputStream()

記憶體輸出流(輸出數據 )

toByteArray()*

public byte [] toByteArray()
  • 將所有保存在記憶體中的位元組數據變為位元組數組存在
  • 將兩個文件利用 toByteArray() 進行合併輸出*
public class TestDemo {
    public static void main(String [] args) throws IOException {
        File fileA = new File("F:" + File.separator + "demo" + File.separator + "demo.txt");
        File fileB = new File("F:" + File.separator + "demo" + File.separator + "data.txt");
        InputStream inA = new FileInputStream(fileA);
        InputStream inB = new FileInputStream(fileB);
        ByteArrayOutputStream output = new ByteArrayOutputStream();
        int temp = 0 ;
        while((temp = inA.read()) != -1) { //讀取A數據
            output.write(temp);
        }
        while((temp = inB.read()) != -1) { //讀取B數據
            output.write(temp);
        }
        // 讀取A,B文件結束後,將記憶體中的所有位元組數據轉為位元組數組
        byte [] data = output.toByteArray();
        inA.close();
        inB.close();
        output.close();
        System.out.println(new String(data));
    }
}

實例

public class TestDemo {
    public static void main(String [] args) throws IOException {
        String str = "Hello,World!";
        InputStream in = new ByteArrayInputStream(str.getBytes());
        // 將所有要讀取的數據設置大記憶體輸入流中
        OutputStream out = new ByteArrayOutputStream();
        // 記憶體輸出流
        int temp = 0 ;// 讀取到的每一個位元組數據
        while ((temp = in.read()) != -1) { // 每次讀取一個位元組數據
            out.write(Character.toUpperCase(temp));//位元組輸出流
            //   temp數據轉大寫並輸出到記憶體輸出流當中
        }
        System.out.println(out);
        in.close();
        out.close();
    }
}

字元記憶體流:

public class CharArrayReader
extends Reader
public class CharArrayWriter
extends Writer

列印流

接觸列印流

如果使用OutputStream,輸出String字元串數據,就需要將String變為位元組數組輸出getBytes(),同理boolean也需要變為Byte數據輸出……

package helloworld;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;

class PrintUtil {
    private OutputStream out; // 輸出依靠 OutputSteam類
    public PrintUtil(OutputStream out) {
        this.out = out ; //確定OutputStream的對象是File……或者ByteArray……
    }
    public void print(int x) throws IOException {
        this.print(String.valueOf(x));//將x轉為String型
    }
    public void print(String x) throws IOException {
        this.out.write(x.getBytes());
    }
    public void print(double x) throws IOException {
        this.print(String.valueOf(x));//將x轉為String型
    }
    public void println(int x) throws IOException {
        this.println(String.valueOf(x));
    }
    public void println(String x) throws IOException {
        this.print(x.concat("\r\n"));
        //在String字元串結尾添加字元[concat()]
    }
    public void println(double x) throws IOException {
        this.println(String.valueOf(x));
    }
    public void close() throws IOException {//關閉輸出流
        this.out.close();
    }
}

public class TestDemo {
    public static void main(String [] args) throws IOException {
        // 調用PrintUtil類的構造方法,實例化對象
        PrintUtil pu = new PrintUtil(
                new FileOutputStream(
                        new File("F:" 
                                    + File.separator + "demo" 
                                    + File.separator + "demo.txt")));
        pu.print("Hello,");
        pu.println("World!");
        pu.println(1+1);
        pu.println(1.1+1.1);
        pu.close();
    }
}

PrintUtil類,則是為了方便列印而設計的一個工具類,在類中,我們通過調用print方法,可以將當前的數據轉為String後在轉為Byte型數據,可以方便我們的數據輸出;避免我們在代碼編寫過程中浪費時間來設計數據類型轉換為Byte位元組輸出。

列印流

  • 為瞭解決上述的數據輸出時的功能不足問題,java.io包提供了一套專門用於輸出數據的類:PrintStream(列印位元組流)PrintWriter(列印字元流)

PrintStream:位元組列印流

  • 繼承結構
java.lang.Object
    java.io.OutputStream
        java.io.FileOutputStream
            java.io.PrintStream
  • 構造方法
PrintStream(OutputStream out)

在PrintStream類中提供了一系列和上述 PrintUtil 類相似的print()、println()方法;這些方法都可支持各種數據類型的輸出,同理:使用了PrintStream,那麼就可以不用去使用write()位元組流輸出方法了。

PrintStream類的實現本質上是基於OutputStream類實現的;這類的設計在Java中稱為 裝飾設計模式 相當於將一個功能不足的操作類,通過某些類的包裝實現成功能健全的更好的操作類。

  • 實現 PrintStream
public class TestDemo {
    public static void main(String [] args) throws IOException {
        // 調用PrintStream類的構造方法,實例化對象
        PrintStream pu = new PrintStream(
                new FileOutputStream(
                        new File("F:" 
                                    + File.separator + "demo" 
                                    + File.separator + "demo.txt")));
        pu.print("Hello,");
        pu.println("World!");
        pu.println(1+1);
        pu.println(1.1+1.1);
        pu.close();
    }
}

將PrintUtil類刪除,使用PrintStream類代替,可以看出操作方法如出一轍。

PrintWrite:字元列印流


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

-Advertisement-
Play Games
更多相關文章
  • 背景 最近工作上有個類似需求是: 現有約3億條數據詞典存在於一個csv文件A中,作為數據源。對於 用戶輸入的任意單詞M,需要快速的在A中匹配M單詞是否存在。(A文件約3G大小左右,總行數三億) 拿到這個需求,你的第一想法怎麼做呢? 正常思路可能是: 上面的方式有個明顯的缺點是:慢! 3億多行的數據, ...
  • 鍵盤錄入兩個數據,返回兩個數中的較大值: 結果: ...
  • 按照Laravel文檔的安裝方式在windows上安裝Laravel時,執行composer global require "laravel/installer"。 然後命令行就顯示Changed current directory to C:/Users/Administrator/AppData ...
  • 花下貓語:本文是學習群內 櫻雨樓 小姐姐的投稿。之前已發佈過她的一篇作品《 "當談論迭代器時,我談些什麼?" 》,大受好評。本文依然是對比 C++ 與 Python,來探討編程語言中極其重要的概念。祝大家讀有所獲,學有所成! 櫻雨樓 | 原創作者 豌豆花下貓 | 編輯潤色 本文原創並首發於公眾號【 ...
  • 1.方法優勢: 提高代碼的復用性 2.什麼是方法: 完成特定功能的代碼塊。 3.方法的格式: 修飾符 返回值類型 方法名(參數類型 參數名1,參數類型 參數名2...) { 方法體語句; return 返回值; } 4.方法的格式說明: 修飾符:目前就用 public static。後面我們再詳細的 ...
  • 基礎數據類型補充以及二次編碼 一.基礎數據類型補充 1.字元串(str) 首字母大寫 每個單詞首字母大寫 大小寫反轉 居中 填充 查找(從左向右,之查找一個) 拼接 格式化 2.列表 定義方式 list(可迭代對象) + 元素都是共用的 排序(預設升序) 降序 反轉 面試題 3.元組 4.字典 定義 ...
  • 方法之兩個整數的求和案例: 結果: ...
  • 異常原因: 對cookie 0版本標準而言,不能直接使用逗號這種特殊符號作為cookie的內容。而新版本的Cookie(參見RFC 2109)目前還不被Javax.servlet.http.Cookie包所支持。 補充: Cookie Version 0中,某些特殊的字元,例如:空格,方括弧,圓括弧 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...