zoukankan      html  css  js  c++  java
  • java第九次作业

    《Java技术》第九次作业

    (一)学习总结

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

    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();
                }      
            }     
        }
    }
    
    • 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,以便将来使用。
    
    
    • 使用BufferedInputStream和BufferedOutputStream类进行修改后的程序:
    import java.io.*;
    public class Test{
    	public static void main(String args[]) throws FileNotFoundException {
    		FileInputStream in=null;
    		FileOutputStream out=null;
    		File fSource=new File("d:"+File.separator+"my.png");
    		File fDest=new File("d:"+File.separator+"java"+File.separator+"my.png");
    		if(!fSource.exists()){ 
    			System.out.println("源文件不存在");   
    			System.exit(1);   
    		}
    		if(!fDest.getParentFile().exists()){   
    			fDest.getParentFile().mkdirs();     
    		}
    		//BufferedInputStream和BufferedOutputStream
    		byte[] buf = new byte[1]; 
    		BufferedInputStream b1 = new BufferedInputStream(new FileInputStream("d:"+File.separator+"my.png"));
    		BufferedOutputStream b2 = new BufferedOutputStream(new FileOutputStream("d:"+File.separator+"java"+File.separator+"my.png"));
    		try {   
    			long begintime = System.currentTimeMillis();
    			while(b1.read(buf)!=-1){      
    				b2.write(buf);           
    			}
    			b2.flush();
    			b1.close();   
                b2.close();
    			long endtime = System.currentTimeMillis();
    			System.out.println("文件拷贝完成,耗时"
    					+(endtime-begintime)+"毫秒");
    		}catch(Exception e){
    			System.out.println("文件操作失败");  
    		}    
    	}     
    
    }
    
    • 显然使用BufferedInputStream和BufferedOutputStream效率更高

    (二)实验总结

    实验内容:
    1.宠物商店:在实验八的基础上,增加一个功能,用文件保存每日的交易信息记录。
    程序设计思路:在程序运行时,首先创建一个record空文件用来存放交易记录(存在了d盘),用追加文本的方式存入交易记录(new FileOutputStream(file,true))

    String msg = new Date(file.lastModified())+":  用户购买了:"+pet.getKind()+"  编号:"+pet.getNo()+"
    ";
    
    out.write(data);
    

    类图结构:

    2.完成文件复制操作,在程序运行后,提示输入源文件路径和目标文件路径。
    程序设计思路:首先输入文件路径和复制的路径,作为字符串输入到fSource和fDest中,
    然后用FileInputStream(fSource)和FileOutputStream(fDest)方法进行复制。

    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)+"毫秒");
    

    (三)代码托管

    • 码云commit历史截图
  • 相关阅读:
    12306-单
    12306-票
    12306-车
    12306-人
    12306-目录
    a+=b 是什么意思?
    开启hadoop和Hbase集群的lzo压缩功能(转)
    HBase性能优化方法总结(转)
    Spark向HDFS中存储数据
    Spark从HDFS上读取JSON数据
  • 原文地址:https://www.cnblogs.com/cheng666/p/6895719.html
Copyright © 2011-2022 走看看