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

    在D盘中保存了一张98KB的图片,运行上面程序,结果如下:

    文件拷贝完成,耗时665毫秒
    
    • BufferedInputStream
      该字节流为另一个输入流添加一些功能,即缓冲输入以及支持 mark 和 reset 方法的能力。在创建 BufferedInputStream 时,会创建一个内部缓冲区数组。在读取或跳过流中的字节时,可根据需要从包含的输入流再次填充该内部缓冲区,一次填充多个字节。mark 操作记录输入流中的某个点,reset 操作使得在从包含的输入流中获取新字节之前,再次读取自最后一次 mark 操作后读取的所有字节。

    • 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类:

    在Java语言的java.io包中,由File类提供了描述文件和目录的操作与管理方法。
    但File类不是InputStream、OutputStream或Reader、Writer的子类,因为它不负责数据的输入输出,而专门用来管理磁盘文件与目录。

    作用:File类主要用于命名文件、查询文件属性和处理文件目录。

    File类共提供了四个不同的构造函数,以不同的参数形式灵活地接收文件和目录名信息。构造函数:

    1)File (String pathname)

     例:File  f1=new File("FileTest1.txt"); //创建文件对象f1,f1所指的文件是在当前目录下创建的FileTest1.txt
    

    2)File(URI uri)

    3)File (String parent , String child)

     例:File f2=new  File(“D:\dir1","FileTest2.txt") ;//  注意:D:\dir1目录事先必须存在,否则异常
    

    4)File (File parent , String child)

     例:  File  f4=new File("E:\dir3");
          File  f5=new File(f4,"FileTest5.txt");  //在如果 E:\dir3目录不存在则需要先使用f4.mkdir()先创建
    

    (二)实验总结

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

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

    程序设计思路:
    1.用户注册系统,设计UsersJFame窗口,显示用户注册页面,定义各属性和输入文本框的位置及大小,定义一个面板,放置注册按钮。在编写图形界面时,再对用户名和密码进行验证,若登录成功,进入宠物商店管理界面。

    2.创建JDBCUtils类,负责数据库连接和关闭操作以及取得数据库的连接对象。

    3.定义宠物信息窗口类,定义三个按钮,查找,购买和显示清单,两个存储工具,分别存储宠物列表和购买的宠物清单。

    4.创建项目运行类,定义MainApp方法,进行测试。

    5.定义copy类,复制并保存每日的交易信息记录的文件。

    问题:注册用户验证,未实现,不能再正确联系其中的关系,复制文件程序,参考教材完成

    (三)代码托管

    码云commit历史截图
    上传实验项目代码到码云,在码云项目中选择“统计-commits”,设置搜索时间段,搜索本周提交历史,并截图。

  • 相关阅读:
    数据结构与算法-字符串与字符串匹配算法
    操作系统-PV操作的原理和几种常见问题
    操作系统-进程(8)-临界区管理
    利用队列实现逐行打印杨辉三角形的前n行
    操作系统-进程(7)死锁和银行家算法
    计算机网络-网络层(6)ICMP协议
    操作系统-进程(6)管程
    计算机网络-链路层(5)点对点链路控制
    操作系统-进程(5)进程通信机制
    RTSP/RTMP流媒体协议网页无插件直播视频平台浏览器请求地址自带尾缀符解释说明
  • 原文地址:https://www.cnblogs.com/HQY110/p/6901482.html
Copyright © 2011-2022 走看看