在編碼領域,通常需要將資料從OutputStream 重定向到InputStream。這種複雜的轉換雖然不像相反的那麼簡單,但可以透過巧妙地利用管道來實現。
解碼管道的力量
Java 的 java.io. PipedInputStream 和 java.io.PipedOutputStream 類別成為此轉換過程中的關鍵角色。它們在 OutputStream 和 InputStream 之間建立單向管道,從而實現資料的無縫傳輸,而不會產生大量記憶體開銷。
Lambda 支援的程式碼可輕鬆轉換
以下內容程式碼片段利用lambda 來簡化轉換:
PipedInputStream in = new PipedInputStream(); final PipedOutputStream out = new PipedOutputStream(in); // in a background thread, write the given output stream to the // PipedOutputStream for consumption new Thread(() -> {originalOutputStream.writeTo(out);}).start();
Try -Resources:一種優雅的方法
另外,try-with-resources 提供了一種優雅的語法用於管理資源:
PipedInputStream in = new PipedInputStream(); new Thread(new Runnable() { public void run () { // try-with-resources here // placing the try block outside the Thread will prematurely close the PipedOutputStream try (final PipedOutputStream out = new PipedOutputStream(in)) { // write the original OutputStream to the PipedOutputStream originalByteArrayOutputStream.writeTo(out); } catch (IOException e) { // logging and exception handling should go here } } }).start();
其他注意事項
如果您無法控制OutputStream 的創建,則可能會遇到ClosedPipeException。要解決此問題,請反轉建構子:
PipedInputStream in = new PipedInputStream(out); new Thread(() -> {originalOutputStream.writeTo(out);}).start();
管道轉換的優點
這種轉換方法在記憶體效率方面表現出色。與創建資料重複副本的其他技術不同,管道僅在流之間建立連接,而不消耗額外的記憶體。此外,在單獨的執行緒中非同步執行可確保最小的延遲並減少資源使用。
以上是如何在 Java 中使用管道將輸出流轉換為輸入流?的詳細內容。更多資訊請關注PHP中文網其他相關文章!