JAVA第九次作业

《JAVA第九次作业》

(一)学习总结

2.下面的程序实现了文件的拷贝,但采用的是一个字节一个字节的读写方式,效率很低。使用缓冲区可以减少对文件的操作次数,从而提高读写数据的效率。IO包中提供了两个带缓冲的字节流BufferedInputStream和BufferedOutputStream,查阅JDK帮助文档,修改程序,利用这两个类完成文件拷贝,对比执行效率。

import java.io.*;
public class Test{
public static void main(String args[]) {
FileInputStream in=null;
FileOutputStream out=null;
File fSource=new File("d:"+File.separator+"my.jpg");
File fDest=new File("d:"+File.separator+"java"+File.separator+"my.jpg");
if(!fSource.exists()){
System.out.println("源文件不存在");
System.exit(1);
}
if(!fDest.getParentFile().exists()){
fDest.getParentFile().mkdirs();
}
try {
in=new FileInputStream(fSource);
out=new FileOutputStream(fDest);
int len=0;
long begintime = System.currentTimeMillis();
while((len=in.read())!=-1){
out.write(len);
}
long endtime = System.currentTimeMillis();
System.out.println("文件拷贝完成,耗时"
+(endtime-begintime)+"毫秒");
}catch(Exception e){
System.out.println("文件操作失败");
}finally{
try {
in.close();
out.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}

使用之前时间为1ms,

使用过之后时间为0ms。

具体方法是:先声明BufferedInputStream,BufferedOutputStream的对象,然后 再将输入输出流给了Buffer类的输入输出流即可。

jdk文档关于BufferedInputStream,BufferedOutputStream的说明:

public BufferedInputStream(InputStream in)创建一个 BufferedInputStream 并保存其参数,即输入流 in,以便将来使用。创建一个内部缓冲区数组并将其存储在 buf 中。 

参数:
in - 底层输入流。
BufferedOutputStream
public BufferedOutputStream(OutputStream out)创建一个新的缓冲输出流,以将数据写入指定的底层输出流。 

参数:
out - 底层输出流。

BufferedOutputStream(OutputStream out) 
      创建一个新的缓冲输出流,以将数据写入指定的底层输出流。
BufferedInputStream(InputStream in) 
  创建一个 BufferedInputStream 并保存其参数,即输入流 in,以便将来使用。

(二)实验总结

2.1实验内容:

宠物商店:在实验八的基础上,增加一个功能,用文件保存每日的交易信息记录。

设计思路:先在窗口设置组件和监听器,写监听器的函数,对购买的编号进行查找,并返回为AnimalItem的一个对象,分别和文本框内的输入的数进行比较,如果没有超出范围则该对象的数量减去购买文本框内的数字,就是剩余的数量,同时更新数据。

新建一个sellAnimalItem类的一个对象sell,当购买成功的时候进行保存数据,保存数据的方法写成一个save的类,通过Buffer的字节流进行保存。

2.完成文件复制操作,在程序运行后,提示输入源文件路径和目标文件路径。

设计思路:提示源文件的路径,进行判断如果不存在则停止,如果存在则提示目标文件的路径,判断,如果目标文件不存在,则新建一个文件,然后进行复制操作。

问题:不太懂,问的同学。

(三)代码托管

posted @ 2017-05-25 17:26  宋伟民  阅读(217)  评论(0编辑  收藏  举报