Java.io.BufferedInputStream.read() 方法



描述

java.io.BufferedInputStream.read(byte[] b, int off, int len) 方法将字节输入流中的 len 个字节读取到字节数组中,从给定的偏移量开始。此方法重复调用底层流的 read() 方法。

迭代读取将持续到以下条件之一成立:

  • 读取了 len 个字节。

  • 返回 -1,表示文件结尾。

  • 如果 BufferedInputStream 的 available() 方法返回 0

声明

以下是 java.io.BufferedInputStream.read(byte[] b, int off, int len) 方法的声明。

public int read(byte[] b, int off, int len)

参数

  • b − 要填充的字节数组。

  • off − 从偏移量开始存储。

  • len − 要读取的字节数。

返回值

此方法不返回值。

异常

IOException − 如果发生 I/O 错误。

示例

以下示例演示了 java.io.BufferedInputStream.read(byte[] b, int off, int len) 方法的使用。

package com.tutorialspoint;

import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.InputStream;

public class BufferedInputStreamDemo {
   public static void main(String[] args) throws Exception {
      InputStream inStream = null;
      BufferedInputStream bis = null;

      try {
         // open input stream test.txt for reading purpose.
         inStream = new FileInputStream("c:/test.txt");
         
         // input stream is converted to buffered input stream
         bis = new BufferedInputStream(inStream);
         
         // read number of bytes available
         int numByte = bis.available();
         
         // byte array declared
         byte[] buf = new byte[numByte];
         
         // read byte into buf , starts at offset 2, 3 bytes to read
         bis.read(buf, 2, 3);
         
         // for each byte in buf
         for (byte b : buf) {
            System.out.println((char)b+": " + b);
         }
      } catch(Exception e) {
         e.printStackTrace();
      } finally {
         // releases any system resources associated with the stream
         if(inStream!=null)
            inStream.close();
         if(bis!=null)
            bis.close();
      }	
   }
}

假设我们有一个文本文件 c:/test.txt,其内容如下。此文件将用作示例程序的输入:

ABCDE  

让我们编译并运行上述程序,这将产生以下结果:

  : 0
  : 0
A: 65
B: 66
C: 67
java_io_bufferedinputstream.htm
广告