java.io.BufferedReader.read(char[] cbuf, int off, int len) 方法读取len个字符到一个具体确定的数组,从偏移量off开始。此方法通过多次调用底层流的read方法读取字符。
更多教程请访问http://www.manongzj.com
该方法停止读取,如果执行下列操作之一为true。
- 流的字符指定数量已读。
- 如果已经达到文件的结束。
- ready方法返回false。
声明
以下是java.io.BufferedReader.read(char[] cbuf, int off, int len) 方法的声明
public int read(char[] cbuf, int off, int len)
参数
-
cbuf -- 目的缓冲区。
-
off -- 偏移量开始存储字符。
-
len -- 要读取的字符数。
返回值
该方法返回一个字符为整数。如果流已到达末尾,那么该方法返回-1。
异常
-
IOException -- -- 如果发生I/ O错误
例子
下面的例子显示java.io.BufferedReader.read(char[] cbuf, int off, int len)方法的用法。
package com.yiibai;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.InputStream;
import java.io.InputStreamReader;
public class BufferedReaderDemo {
public static void main(String[] args) throws Exception {
InputStream is = null;
InputStreamReader isr = null;
BufferedReader br = null;
try{
// open input stream test.txt for reading purpose.
is = new FileInputStream("c:/test.txt");
// create new input stream reader
isr = new InputStreamReader(is);
// create new buffered reader
br = new BufferedReader(isr);
// creates buffer
char[] cbuf = new char[is.available()];
// reads characters to buffer, offset 2, len 10
br.read(cbuf, 2, 10);
// for each character in the buffer
for (char c:cbuf)
{
// if char is empty
if(c == (char)0)
{
c='*';
}
// prints characters
System.out.print(c);
}
}catch(Exception e){
e.printStackTrace();
}finally{
// releases resources associated with the streams
if(is!=null)
is.close();
if(isr!=null)
isr.close();
if(br!=null)
br.close();
}
}
}
假设有一个文本文件c:/ test.txt,它具有以下内容。该文件将被用作输入在我们的示例程序:
ABCDEFGHIJKLMNOPQRSTUVWXYZ
让我们来编译和运行上面的程序,这将产生以下结果:
**ABCDEFGHIJ**************