java中read()方法的使用
3个回答
展开全部
字节流的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方式进行逐行的读取。
展开全部
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时文件结束。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询