一、简介
Java ByteArrayInputStream类实现了一个输入流,其中数据从字节数组中读取。它主要用于在Java应用程序中读取字节数组作为输入数据流的源。ByteArrayInputStream类继承于InputStream类,在Java IO中具有重要的作用。
二、类定义
public class ByteArrayInputStream extends InputStream
三、构造函数
ByteArrayInputStream类有两种构造函数,分别如下:
public ByteArrayInputStream(byte[] buf) public ByteArrayInputStream(byte[] buf, int offset, int length)
第一个构造函数使用buf作为内部缓冲区,缓冲区的初始大小为buf.length。第二个方法使用buf作为内部缓冲区,缓冲区的初始大小为length,并且从数组中的offset位置开始读取数据。只有buf的子数组buf[offset]到buf[offset+length-1]之间的数据被缓存并可供使用。
四、常规方法
Java ByteArrayInputStream类提供了一些常规方法以操作字节数组数据流。
1、available()
该方法返回ByteArrayInputStream中尚未读取的字节数。
public int available()
2、read()
该方法从ByteArrayInputStream中读取下一个字节,并将其作为int返回。如果达到文件末尾,则返回-1。
public int read()
3、read(byte[] b, int off, int len)
该方法将ByteArrayInputStream中的数据读入给定的数组b中。从off开始的数据将写入数组,只写len个字节或直到ByteArrayInputStream达到末尾为止。返回实际读取的字节数。
public int read(byte[] b, int off, int len)
4、reset()
该方法将流的读位置重新设置到开始处,即标记处。如果该流不支持标记,则抛出IOException。
public void reset() throws IOException
5、mark()
该方法将流的当前位置设置为标记位置,以备后续重置使用。标记过程可能会因为使用的缓冲区太小而失败,如果确实失败了,该方法将抛出IOException。
public void mark(int readAheadLimit)
五、示例代码
下面是一个用Java ByteArrayInputStream类读取字节数组中的数据的示例代码的示例。
import java.io.ByteArrayInputStream; public class ByteArrayInputStreamDemo { public static void main(String args[])throws Exception { byte[] buf = { 35, 36, 37, 38 }; ByteArrayInputStream byt = new ByteArrayInputStream(buf); int c; //读取并显示字节数组中的数据 while ((c = byt.read()) != -1) { System.out.println(c); } // 重置流的位置 byt.reset(); //创建一个新的byte数组 byte[] newbuf = new byte[buf.length]; byt.read(newbuf, 0, newbuf.length); //显示新的byte数组的内容 System.out.println("新的Byte数组内容:"); for (int i = 0; i < newbuf.length; i++) { System.out.println((char) newbuf[i]); } } }
该程序的输出如下所示:
35 36 37 38 新的Byte数组内容: # $ % &
六、总结
Java ByteArrayInputStream类主要用于读取字节数组作为数据源的输入流。使用该类,可以轻松读取和处理字节数组。该类提供许多有用的方法来读取和操作字节数组数据流。在需要读取字节数组的场合使用Java ByteArrayInputStream类是一个不错的选择。