zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    Spark RDD 创建(一)
    编译Spark-1.6.0源码
    Strom学习笔记一
    Hbase笔记——RowKey设计
    Hbase物理模型
    HDFS分布式文件系统设计思想
    Hbase 基本命令
    内部排序算法
    278. First Bad Version
    266. Palindrome Permutation
  • 原文地址:https://www.cnblogs.com/hfja/p/6902279.html
Copyright © 2011-2022 走看看