java第六次作业

《Java技术》第六次作业

(一)学习总结

1.用思维导图对本周的学习内容进行总结。

2.当程序中出现异常时,JVM会依据方法调用顺序依次查找有关的错误处理程序。可使用printStackTrace 和getMessage方法了解异常发生的情况。阅读下面的程序,说明printStackTrace方法和getMessage 方法的输出结果分别是什么?并分析异常的传播过程。

public class PrintExceptionStack {
    public static void main( String args[] )
    {
         try {
             method1();
          } catch ( Exception e ) {
             System.err.println( e.getMessage() + "\n" );
             e.printStackTrace();
          }
    }
   public static void method1() throws Exception
   {
      method2();
   }
   public static void method2() throws Exception
   {
      method3();
   }
   public static void method3() throws Exception
   {
      throw new Exception( "Exception thrown in method3" );
   }
}
  • getMessage 方法的输出结果

      Exception thrown in method3
    

String getMessage():返回此throwable详细信息字符串。

  • printStackTrace方法的输出结果

      java.lang.Exception: Exception thrown in method3
      	at PrintExceptionStack.method3(PrintExceptionStack.java:20)
      	at PrintExceptionStack.method2(PrintExceptionStack.java:16)
      	at PrintExceptionStack.method1(PrintExceptionStack.java:12)
      	at PrintExceptionStack.main(PrintExceptionStack.java:4)
    

void printStackTrace():将此 throwable对象的堆栈跟踪输出至错误输出流。

  • 异常传播过程:method3()产生异常并抛出,method2() 调用method3()产生异常并抛出,method1() 调用method2()产生异常并抛出,主函数调用method1()产生异常并捕获用

      try  {
         
      }catch() {
        
      }
    

包围。

3.阅读下面程序,分析程序的运行结果,解释产生错误的原因,如果删除的是books集合的最后一个对象,运行的结果又是什么?你能对此作出解释吗?如果在遍历时非要删除集合中的元素,应如何实现?

import java.util.*;
public class Test
{
    public static void main(String[] args) 
    {
        Collection<String> books = new ArrayList<String>();
        books.add("One book");
        books.add("Two book");
        books.add("Three book");
        System.out.println("原始元素之后:"+books);
        Iterator<String> it = books.iterator();
        while(it.hasNext())
        {
            String book = (String)it.next();
            System.out.println(book);
            if (book.equals("One book"))
            {
                books.remove(book);
            }
        }
        System.out.println("移除元素之后:"+books);
    }
}
  • 错误原因:再进行删除时,会使迭代器的内容发生改变,造成异常。

  • 删除books集合的最后一个对象,运行的结果是

        原始元素之后:[One book, Two book, Three book]
          One book
          Two book
          Three book
          Exception in thread "main"java.util.ConcurrentModificationException
          at java.util.ArrayList$Itr.checkForComodification(ArrayList.java:819)                                                                      at java.util.ArrayList$Itr.next(ArrayList.java:791)
          at lalal.PrintExceptionStack.main(PrintExceptionStack.java:16)
    
  • 原因与上一个同理。

  • 解决方法:使用迭代器本身的删除方法。

  • 代码为:

      import java.util.*;
      public class Test {
          public static void main(String[] args) {
              Collection<String> books = new ArrayList<String>();
              books.add("One book");
              books.add("Two book");
              books.add("Three book");
              System.out.println("原始元素之后:" + books);
              Iterator<String> it = books.iterator();
                   while (it.hasNext()) {
                   String book = (String) it.next();
                   System.out.println(book);
                   if (book.equals("One book")) {
                      it.remove();
                  }
              }
            System.out.println("移除元素之后:" + books);
          }
      }
    

4.HashSet存储的元素是不可重复的。运行下面的程序,分析为什么存入了相同的学生信息?如果要去掉重复元素,应该如何修改程序。

    import java.util.*;
    class Student {
        String id;  
        String name;
        public Student(String id, String name) {
            this.id = id;
            this.name = name;
        }
        public String toString() {
            return "Student id=" + id + ", name=" + name ;
        }
    }
    public class Test
    {
        public static void main(String[] args) 
        {
            HashSet<Student> set = new HashSet<Student>();
            set.add(new Student("1","Jack"));
            set.add(new Student("2","Rose"));
            set.add(new Student("2","Rose"));
            System.out.println(set);                
        }
    }
  • 原因:因为内存空间不一样,引用时会被当做不同的对象处理。

  • 解决方案:在Student中重写hashCode()方法和equals()方法。可用源代码直接添加。

  • 添加后代码为:

      import java.util.*;
      
      class Student {
      	String id;
      	String name;
      
      	public Student(String id, String name) {
      		this.id = id;
      		this.name = name;
      	}
      
      	public String toString() {
      		return "Student id=" + id + ", name=" + name;
      	}
      
      	@Override
      	public int hashCode() {
      		final int prime = 31;
      		int result = 1;
      		result = prime * result + ((id == null) ? 0 : id.hashCode());
      		result = prime * result + ((name == null) ? 0 : name.hashCode());
      		return result;
      	}
      
      	@Override
      	public boolean equals(Object obj) {
      		if (this == obj)
      			return true;
      		if (obj == null)
      			return false;
      		if (getClass() != obj.getClass())
      			return false;
      		Student other = (Student) obj;
      		if (id == null) {
      			if (other.id != null)
      				return false;
      		} else if (!id.equals(other.id))
      			return false;
      		if (name == null) {
      			if (other.name != null)
      				return false;
      		} else if (!name.equals(other.name))
      			return false;
      		return true;
      	}
      	
      }
      
      public class Test {
      	public static void main(String[] args) {
      		HashSet<Student> set = new HashSet<Student>();
      		set.add(new Student("1", "Jack"));
      		set.add(new Student("2", "Rose"));
      		set.add(new Student("2", "Rose"));
      		System.out.println(set);
      	}
      }
    

(二)实验总结

1.模拟KTV点歌系统

  • 分别用LinkedList和ArrayList集合,实现一个模拟KTV点歌系统的程序。实现以下功能:
    (1)显示歌曲列表
    (2)添加歌曲到列表
    (3)删除歌曲
    (4)将歌曲置顶
    (5)将歌曲前移一位
    (6)退出
    题目扩展:歌曲包括曲名、演唱者。增加排序显示歌曲列表功能。

  • 程序设计思路:设计一个功能类,写实现功能的方法,歌曲包括曲名、演唱者是通过Song类实现的,最后Test类测试。

  • 实验问题分析:
    问题1:在执行添加后再进行输出时添加的内容未输出。
    解决方案:进行了传参

     public void show(List<Song> songs) 
     public void Add(List<Song> songs, String song, String singer)
    

2.模拟微博用户注册

  • 用HashSet实现一个模拟微博用户注册的程序。用户输入用户名、密码、确认密码、生日(格式yyyy-mm-dd)、手机号码(11位,13、15、17、18开头)、邮箱信息进行微博的注册。要求对用户输入的信息进行验证,输入信息正确后,验证是否重复注册,如果不是则注册成功,否则注册失败。
    提示:
    (1)设计一个用户类存储用户注册信息
    (2)设计一个校验信息类,定义校验方法完成对输入信息的校验。学习使用正则表达式完成对生日、手机号码和邮箱的验证。
    (3)设计一个用户注册类模拟注册过程。用HashSet存储用户数据列表,定义一个initData()方法添加初始用户信息。在main方法中完成用户注册功能。

  • 程序设计思路:设计思路为老师提示内容。

  • 实验问题分析:
    问题1:在进行已有用户名不能添加时不知道怎么判断。
    解决方案:询问同学后,添加以下语句:

     if (user.add(new User(str1, str2, str3, str4, str5))) {
     			System.out.println("注册成功");
     }
    

(三)[代码托管] https://git.oschina.net/hebau_cs15/hebau-cs01cyl.git

  • 码云commit历史截图

(四)学习进度条

代码行数(新增/累积) 学习时间(新增/累积) 本周学习内容
目标 5000行 300小时
第2-4周
第5周
第9周 150 15 学习了抽象类,接口等面向对象的知识点
第10周 150 20 学习了异常处理,泛型,java集类
posted @ 2017-05-01 20:19  曾经的曾经···  阅读(231)  评论(1编辑  收藏  举报