Java第九次作业--输入输出流和文件操作

(一)学习总结

1.用思维导图对javaIO操作的学习内容进行总结。

参考资料: XMind。

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();
            }      
        }     
    }
}

运行结果为:

文件拷贝完成,耗时632毫秒

BufferedInputStream
BufferedInputStream 是缓冲输入流。它继承于FilterInputStream。 BufferedInputStream 的作用是为另一个输入流添加一些功能,例如,提供“缓冲功能”以及支持“mark()标记”和“reset()重置方法”。 BufferedInputStream 本质上是通过一个内部缓冲区数组实现的。
BufferedOutputStream
BufferedOutputStream 是缓冲输出流。它继承于FilterOutputStream。 BufferedOutputStream 的作用是为另一个输出流提供“缓冲功能”。
修改后的程序:

import java.io.*;
public class Test {
    public static void main(String args[]) {
        FileInputStream in = null;
        FileOutputStream out = null;
        BufferedInputStream bis=null;  
        BufferedOutputStream bos=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);
            bis=new BufferedInputStream(in);
            out = new FileOutputStream(fDest);
            bos=new BufferedOutputStream(out);
            byte[] buff = new byte[1024];
            int len = 0;
            long begintime = System.currentTimeMillis();
            while ((len = in.read(buff)) != -1) {
                out.write(buff, 0, 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();
            }
        }
    }
}

运行结果为:

文件拷贝完成,耗时2毫秒

3.其他需要总结的内容。
File类构造方法:
(1)public File(String path)
(2)如果path是实际存在的路径,则该File对象表示的是目录;
(3)如果path是文件名,则该File对象表示的是文件。
(4)public File(String path , String name) ;
(5)public File(File dir , String name) ;
输入输出流基本的操作原理:
(1)使用File类找到一个文件
(2)通过字节流或字符流的子类进行对象的实例化
(3)进行读或写的操作
(4)关闭字节或字符流

(二)实验总结

实验内容:
1.宠物商店:在实验八的基础上,增加一个功能,用文件保存每日的交易信息记录。
2.完成文件复制操作,在程序运行后,提示输入源文件路径和目标文件路径。

完成实验内容,代码上传到码云,注意,宠物商店要求务必将创建数据库的脚本文件随项目文件一起上传,在随笔中分析程序设计思路,用PowerDesigner画出类图结构,并对完成实验内容过程中遇到的问题、解决方案和思考等进行归纳总结,注意代码中必须有必要的注释。

(三)代码托管

https://git.oschina.net/hfja/java-CS02hfj.git

原文地址:https://www.cnblogs.com/hfja/p/6902279.html