4个回答
展开全部
字节流的read()方法是操作字节流的,字符流的read()方法是操作unicode字符的。
可以通过BufferedReader 流的形式进行流缓存,通过read()方法获取到缓存的内容。
示例代码:
BufferedReader bre = null;
try {
String file = "X:/xxxx/xxxx.txt";//文件地址
bre = new BufferedReader(new FileReader(file));//获取到的bre就是整个文件的缓存流
while ( bre.read() != -1) {// 判断是否为最后一个字节,若是则结束循环
System.out.println(bre.read());//输出读到的内容
};
bre.close();//切记需要写close()关闭流
备注:字节流读取过程中很容易出现乱码,建议可以用readLine方式进行逐行的读取。
可以通过BufferedReader 流的形式进行流缓存,通过read()方法获取到缓存的内容。
示例代码:
BufferedReader bre = null;
try {
String file = "X:/xxxx/xxxx.txt";//文件地址
bre = new BufferedReader(new FileReader(file));//获取到的bre就是整个文件的缓存流
while ( bre.read() != -1) {// 判断是否为最后一个字节,若是则结束循环
System.out.println(bre.read());//输出读到的内容
};
bre.close();//切记需要写close()关闭流
备注:字节流读取过程中很容易出现乱码,建议可以用readLine方式进行逐行的读取。
2015-09-13 · 知道合伙人互联网行家
关注
展开全部
Java从文件中读取内容使用read方法,如下:
//测试文件流的写入读出
public void fileTest()
{
try {
FileOutputStream out2 = new FileOutputStream("hello.txt");
out2.write("a".getBytes());
out2.write("b".getBytes());
out2.write("c".getBytes());
out2.write("d".getBytes());
out2.write("e".getBytes());
out2.close();
File file = new File("hello.txt");
FileInputStream in = new FileInputStream(file);
byte[] buf = new byte[12];
int len1 = in.read(buf,0,3);
int len2 = in.read(buf,0,4);
in.close();
System.out.println(buf.toString());
System.out.println("len1="+len1+"len2="+len2);
System.out.println(new String(buf, 0, 8));
in.close();
} catch (Exception e)
{
e.printStackTrace();
}
}12345678910111213141516171819202122232425262728293031
输出结果:
[B@1db9742
len1=3len2=2
dec123
解释:read函数的参数含义
buf:读出后放到的缓存位置;
arg1:从buf哪里开始存放;
arg2:读取的长度;
返回值为读取到的长度。
FileInputStream调用read函数,是顺序读取,只读一遍,所以第一读取的为abc,第二次读取的为de,然后都从0写入buf,将ab覆盖,所以输出为dec。
//测试文件流的写入读出
public void fileTest()
{
try {
FileOutputStream out2 = new FileOutputStream("hello.txt");
out2.write("a".getBytes());
out2.write("b".getBytes());
out2.write("c".getBytes());
out2.write("d".getBytes());
out2.write("e".getBytes());
out2.close();
File file = new File("hello.txt");
FileInputStream in = new FileInputStream(file);
byte[] buf = new byte[12];
int len1 = in.read(buf,0,3);
int len2 = in.read(buf,0,4);
in.close();
System.out.println(buf.toString());
System.out.println("len1="+len1+"len2="+len2);
System.out.println(new String(buf, 0, 8));
in.close();
} catch (Exception e)
{
e.printStackTrace();
}
}12345678910111213141516171819202122232425262728293031
输出结果:
[B@1db9742
len1=3len2=2
dec123
解释:read函数的参数含义
buf:读出后放到的缓存位置;
arg1:从buf哪里开始存放;
arg2:读取的长度;
返回值为读取到的长度。
FileInputStream调用read函数,是顺序读取,只读一遍,所以第一读取的为abc,第二次读取的为de,然后都从0写入buf,将ab覆盖,所以输出为dec。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
字节流的read是操作字节流的,字符流的read是操作unicode字符的。
不带参数返回单一数据,否则需要一个数线参数以读多个数据。
文件小时,可创建与文件等同大小的数组来读,如果文件较大,特别是文件长度可能是长整,而数组元素个数只能是整数,这时可以使用一个较小的数组,循环读。
每次读的返回值有用,表示读到的字节数。为-1时文件结束。
不带参数返回单一数据,否则需要一个数线参数以读多个数据。
文件小时,可创建与文件等同大小的数组来读,如果文件较大,特别是文件长度可能是长整,而数组元素个数只能是整数,这时可以使用一个较小的数组,循环读。
每次读的返回值有用,表示读到的字节数。为-1时文件结束。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
inputStream
int read(byte[] b)
从输入流中读取一定数量的字节并将其存储在缓冲区数组 b 中。
int read(byte[] b, int off, int len)
将输入流中最多 len 个数据字节读入字节数组。
具体查一下API
int read(byte[] b)
从输入流中读取一定数量的字节并将其存储在缓冲区数组 b 中。
int read(byte[] b, int off, int len)
将输入流中最多 len 个数据字节读入字节数组。
具体查一下API
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询