《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();
        	}      
    	}     
	}
}
  • BufferedInputStream
    • 在创建 BufferedInputStream 时,会创建一个内部缓冲区数组。在读取或跳过流中的字节时,可根据需要从包含的输入流再次填充该内部缓冲区,一次填充多个字节。

  • BufferedOutputStream

    • 通过设置这种输出流,应用程序就可以将各个字节写入底层输出流中,而不必针对每次字节写入调用底层系统。
      try {   
      	    in=new FileInputStream(fSource);
      	    out=new FileOutputStream(fDest);
      	    /*int len=0;
      	    long begintime = System.currentTimeMillis();
      	    while((len=in.read())!=-1){
      	        out.write(len);          
      	    } */
      	    byte[] buff=new byte[1024];
      	    int len=0;
      	    long begintime=System.currentTimeMillis();
      	    while((len=in.read(buff))!=-1){
      	        out.write(buff,0,len);          
      	    } 
    

  • BufferedInputStream和BufferedOutputStream的执行效率
    • BufferedOutputStream执行效率远高于BufferedInputStream

(二)实验总结

  • 实验内容:

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

    1.定义用户登录界面,编写登录验证类,在验证类中只是根据输入进来的用户名和密码进行验证,并没有注册功能,在编写图形界面时,再对用户名和密码进行验证,若登录成功,进入宠物商店管理界面。

    2.创建Pet类,定义宠物的基本属性;创建SellPet类,定义即将卖的宠物的属性。

    3.在工具类中,创建JDBCUtils类,负责数据库连接和关闭操作以及取得一个数据库的连接对象;创建FileUtils类实现将购买的宠物数据添加到excel表格。

    4.定义宠物商店管理窗口类,定义查询、添加、修改、购买、删除方法,设置窗口界面,在数据库中获取数据,添加到表格。

    5.创建管理类,实现宠物的查询、添加、修改、删除方法。

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

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

  • 类图结构:

  • 问题1:当输入宠物编号,如果出现编号与商店宠物编号不符时,即离开出现错误,不必在最后检查,简化了操作。

  • 解决方案:

      addNoText.addFocusListener(new FocusAdapter() {
      	public void focusLost(FocusEvent e) {
      		ArrayList<Pet> data = service.queryPet();
      		Iterator<Pet> iterator = data.iterator();
      		while (iterator.hasNext()) {
      			Pet pet = iterator.next();
      			// 如果存在重复编号则添加不成功
      			if (pet.getNo().equals(addNoText.getText())) {
      				JOptionPane.showMessageDialog(null, "宠物编号不能重复,请检查数据");
      				addNoText.setText("");
      				addNoText.requestFocus();
      			}
      		}
      	}
      });
    
  • 问题2:运行时,数据库对实现宠物的添加等各种方法没有数据显示。

  • 原因:数据库的名字填写错误。

(三)代码托管

  • 码云commit历史截图
posted @ 2017-05-21 22:51  lymm  阅读(221)  评论(0)    收藏  举报