程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Java中的BufferedInputStream與BufferedOutputStream應用示例

Java中的BufferedInputStream與BufferedOutputStream應用示例

編輯:關於JAVA

Java中的BufferedInputStream與BufferedOutputStream應用示例。本站提示廣大學習愛好者:(Java中的BufferedInputStream與BufferedOutputStream應用示例)文章只能為提供參考,不一定能成為您想要的結果。以下是Java中的BufferedInputStream與BufferedOutputStream應用示例正文


BufferedInputStream 
BufferedInputStream 是緩沖輸出流。它繼續於FilterInputStream。
BufferedInputStream 的感化是為另外一個輸出流添加一些功效,例如,供給“緩沖功效”和支撐“mark()標志”和“reset()重置辦法”。
BufferedInputStream 實質上是經由過程一個外部緩沖區數組完成的。例如,在新建某輸出流對應的BufferedInputStream後,當我們經由過程read()讀取輸出流的數據時,BufferedInputStream會將該輸出流的數據分批的填入到緩沖區中。每當緩沖區中的數據被讀完以後,輸出流會再次填湊數據緩沖區;如斯重復,直到我們讀完輸出流數據地位。
BufferedInputStream 函數列表:

BufferedInputStream(InputStream in)
BufferedInputStream(InputStream in, int size)

synchronized int   available()
void   close()
synchronized void   mark(int readlimit)
boolean   markSupported()
synchronized int   read()
synchronized int   read(byte[] buffer, int offset, int byteCount)
synchronized void   reset()
synchronized long   skip(long byteCount)

示例代碼:
關於BufferedInputStream中API的具體用法,參考示例代碼(BufferedInputStreamTest.java):

import java.io.BufferedInputStream;
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.InputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.FileNotFoundException;
import java.lang.SecurityException;

/**
 * BufferedInputStream 測試法式
 *
 * @author skywang
 */
public class BufferedInputStreamTest {

  private static final int LEN = 5;

  public static void main(String[] args) {
    testBufferedInputStream() ;
  }

  /**
   * BufferedInputStream的API測試函數
   */
  private static void testBufferedInputStream() {

    // 創立BufferedInputStream字撙節,內容是ArrayLetters數組
    try {
      File file = new File("bufferedinputstream.txt");
      InputStream in =
         new BufferedInputStream(
           new FileInputStream(file), 512);

      // 從字撙節中讀取5個字節。“abcde”,a對應0x61,b對應0x62,順次類推...
      for (int i=0; i<LEN; i++) {
        // 若能持續讀取下一個字節,則讀取下一個字節
        if (in.available() >= 0) {
          // 讀取“字撙節的下一個字節”
          int tmp = in.read();
          System.out.printf("%d : 0x%s\n", i, Integer.toHexString(tmp));
        }
      }

      // 若“該字撙節”不支撐標志功效,則直接加入
      if (!in.markSupported()) {
        System.out.println("make not supported!");
        return ;
      }

      // 標志“以後索引地位”,即標志第6個地位的元素--“f”
      // 1024對應marklimit
      in.mark(1024);

      // 跳過22個字節。
      in.skip(22);

      // 讀取5個字節
      byte[] buf = new byte[LEN];
      in.read(buf, 0, LEN);
      // 將buf轉換為String字符串。
      String str1 = new String(buf);
      System.out.printf("str1=%s\n", str1);

      // 重置“輸出流的索引”為mark()所標志的地位,即重置到“f”處。
      in.reset();
      // 從“重置後的字撙節”中讀取5個字節到buf中。即讀取“fghij”
      in.read(buf, 0, LEN);
      // 將buf轉換為String字符串。
      String str2 = new String(buf);
      System.out.printf("str2=%s\n", str2);

      in.close();
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    } catch (SecurityException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
}

法式中讀取的bufferedinputstream.txt的內容以下:

abcdefghijklmnopqrstuvwxyz
0123456789
ABCDEFGHIJKLMNOPQRSTUVWXYZ

運轉成果:

0 : 0x61
1 : 0x62
2 : 0x63
3 : 0x64
4 : 0x65
str1=01234
str2=fghij

BufferedOutputStream 
BufferedOutputStream 是緩沖輸入流。它繼續於FilterOutputStream。
BufferedOutputStream 的感化是為另外一個輸入流供給“緩沖功效”。
BufferedOutputStream 函數列表:

BufferedOutputStream(OutputStream out)
BufferedOutputStream(OutputStream out, int size)

synchronized void   close()
synchronized void   flush()
synchronized void   write(byte[] buffer, int offset, int length)
synchronized void   write(int oneByte)

示例代碼:
關於BufferedOutputStream中API的具體用法,參考示例代碼(BufferedOutputStreamTest.java):

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.OutputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.FileNotFoundException;
import java.lang.SecurityException;
import java.util.Scanner;

/**
 * BufferedOutputStream 測試法式
 *
 * @author skywang
 */
public class BufferedOutputStreamTest {

  private static final int LEN = 5;
  // 對應英文字母“abcddefghijklmnopqrsttuvwxyz”
  private static final byte[] ArrayLetters = {
    0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68, 0x69, 0x6A, 0x6B, 0x6C, 0x6D, 0x6E, 0x6F,
    0x70, 0x71, 0x72, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78, 0x79, 0x7A
  };

  public static void main(String[] args) {
    testBufferedOutputStream() ;
  }

  /**
   * BufferedOutputStream的API測試函數
   */
  private static void testBufferedOutputStream() {

    // 創立“文件輸入流”對應的BufferedOutputStream
    // 它對應緩沖區的年夜小是16,即緩沖區的數據>=16時,會主動將緩沖區的內容寫入到輸入流。
    try {
      File file = new File("out.txt");
      OutputStream out =
         new BufferedOutputStream(
           new FileOutputStream(file), 16);

      // 將ArrayLetters數組的前10個字節寫入到輸入流中
      out.write(ArrayLetters, 0, 10);
      // 將“換行符\n”寫入到輸入流中
      out.write('\n');

      // TODO!
      //out.flush();

      readUserInput() ;

      out.close();
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    } catch (SecurityException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }

  /**
   * 讀取用戶輸出
   */
  private static void readUserInput() {
    System.out.println("please input a text:");
    Scanner reader=new Scanner(System.in);
    // 期待一個輸出
    String str = reader.next();
    System.out.printf("the input is : %s\n", str);
  }
}

運轉成果:
生成文件“out.txt”,文件的內容是“abcdefghij”。
分步測試: 分離依照上面3種步調測試法式,來檢查緩沖區年夜小和flush()的感化。
第1種:原始法式
(1) 運轉法式。在法式期待用戶輸出時,檢查“out.txt”的文本內容;發明:內容為空。
(2) 運轉法式。在用戶輸出以後,檢查“out.txt”的文本內容;發明:內容為“abcdefghij”。
從中,我們發明(01)和(02)的成果分歧;之所以(01)中的out.txt內容為空,是由於out.txt對應的緩沖區年夜小是16字節,而我們只寫入了11個字節,所以,它不會履行清空緩沖操作(即,將緩沖數據寫入到輸入流中)。
而(02)對應out.txt的內容是“abcdefghij”,是由於履行了out.close(),它會封閉輸入流;在封閉輸入流之前,會將緩沖區的數據寫入到輸入流中。
留意:從新測試時,要先刪除out.txt。
第2種:在readUserInput()前添加以下語句
out.flush();
這句話的感化,是將“緩沖區的內容”寫入到輸入流中。
(1) 運轉法式。在法式期待用戶輸出時,檢查“out.txt”的文本內容;發明:內容為“abcdefghij”。
(2) 運轉法式。在用戶輸出以後,檢查“out.txt”的文本內容;發明:內容為“abcdefghij”。
從中,我們發明(01)和(02)成果一樣,對應out.txt的內容都是“abcdefghij”。這是由於履行了flush()操作,它的感化是將緩沖區的數據寫入到輸入流中。
留意:從新測試時,要先刪除out.txt!
第3種:在第1種的基本上,將

out.write(ArrayLetters, 0, 10);

修正為

out.write(ArrayLetters, 0, 20);

(1) 運轉法式。在法式期待用戶輸出時,檢查“out.txt”的文本內容;發明:內容為“abcdefghijklmnopqrst”(不含回車)。
(02) 運轉法式。在用戶輸出以後,檢查“out.txt”的文本內容;發明:內容為“abcdefghijklmnopqrst”(含回車)。
從中,我們發明(01)運轉成果是“abcdefghijklmnopqrst”(不含回車)。這是由於,緩沖區的年夜小是16,而我們經由過程out.write(ArrayLetters, 0, 20)寫入了20個字節,跨越了緩沖區的年夜小;這時候,會直接將全體的輸出都寫入都輸入流中,而不經由緩沖區。
(3)運轉成果是“abcdefghijklmnopqrst”(含回車),這是由於履行out.close()時,將回車符號'\n'寫入了輸入流中。
留意:從新測試時,要先刪除out.txt!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved