黑马程序员技术交流社区
标题:
缓冲区中readLine方法问题
[打印本页]
作者:
z-翔
时间:
2014-7-24 22:27
标题:
缓冲区中readLine方法问题
本帖最后由 z-翔 于 2014-7-25 16:36 编辑
关于毕老师讲的自定义的缓冲区的readLine方法里,我把注释的部分改了一下
换成了红色部分的,运行没有问题,不知道有没有其他问题,请大家帮忙看一下
还有就是那个private一定要加吗?
import java.io.*;
public class MyBufferedDemo
{
public static void main(String[] args) throws IOException
{
FileReader fr = new FileReader("d:\\Demo.txt");
MyBufferedReader m = new MyBufferedReader(fr);
String line = null;
while((line=m.myReadLine())!=null)
{
System.out.println(line);
}
m.myClose();
}
}
class MyBufferedReader
{
private
FileReader fr = null;
MyBufferedReader(FileReader fr)
{
this.fr = fr;
}
public String myReadLine() throws IOException
{
StringBuilder sb = new StringBuilder();
int c = 0;
while ((c=fr.read())!=-1)
{
if(c=='\r')
continue;
if(c=='\n')
break;
//return sb.toString();
sb.append((char)c);
}
/*
if (sb.length()!=0)
return sb.toString();
return null;
*/
if (sb.length()==0)
return null;
return sb.toString();
}
public void myClose()throws IOException
{
fr.close();
}
}
作者:
space2007
时间:
2014-7-24 22:44
没看出有什么问题 本人比较水
作者:
乐此不疲
时间:
2014-7-24 23:09
本帖最后由 乐此不疲 于 2014-7-24 23:12 编辑
看错了 ~~
作者:
215041631
时间:
2014-7-25 02:25
程序运行时没有问题,你把判断都放到了外面。不过你改成BREAK后,还要多一次判断他长度是否为零,就多余了,直接return的话,当然这个程序里这点效率忽略不计了
作者:
215041631
时间:
2014-7-25 02:26
程序运行时没有问题,你把判断都放到了外面。不过你改成BREAK后,还要多一次判断他长度是否为零就多余了,直接return的话效率会好点吧,当然这个程序里这点效率忽略不计了
作者:
wisely
时间:
2014-7-25 02:57
如果文件中间出现空行,那么复制就会停止。
作者:
z-翔
时间:
2014-7-25 08:29
wisely 发表于 2014-7-25 02:57
如果文件中间出现空行,那么复制就会停止。
明白了,谢谢
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2