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

    (一)学习总结

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

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

    Exception thrown in method3
    
    java.lang.Exception: Exception thrown in method3
    	at Test.method3(Test.java:21)
    	at Test.method2(Test.java:17)
    	at Test.method1(Test.java:13)
    	at Test.main(Test.java:5)
    

    try{}语句中包括可能产生异常的语句,catch{}进行对出现的异常进行捕获。采用了throws的捕获异常,所有在调用method1()方法时需要处理异常,但是在method1()中进行throws,所有在调用该方法的时候需要处理,一直到method3()的时候处理了该异常。catch语句中输出了getMessage,信息,为Exception e.get方法。即输出: java.lang.Exception: Exception thrown in method3

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

    Exception in thread "main" java.util.ConcurrentModificationException
    	at java.util.ArrayList$Itr.checkForComodification(Unknown Source)
    	at java.util.ArrayList$Itr.next(Unknown Source)
    	at Test.main(Test.java:14)
    

    删除最后一个元素运行结果同上
    错误原因:使用Iterator迭代输出是若想移除元素不能使用集合类中的remove()方法
    修改:使用Iterator本身的remove()方法

    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存储的元素是不可重复的。运行下面的程序,分析为什么存入了相同的学生信息?如果要去掉重复元素,应该如何修改程序。
    原因:Student类是非系统类,没有覆写hashCode()和equals()方法,无法判断元素是否重复。
    修改:在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 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;
    		}
    		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 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);                
            }
        }
    

    5.其他需要总结的内容。
    .泛型中通配符<?>可以输出,但无法对对象进行修改

    (二)实验总结

    • 1.模拟KTV点歌系统
      分别用LinkedList和ArrayList集合,实现一个模拟KTV点歌系统的程序。实现以下功能:
      (1)显示歌曲列表
      (2)添加歌曲到列表
      (3)删除歌曲
      (4)将歌曲置顶
      (5)将歌曲前移一位
      (6)退出
      题目扩展:歌曲包括曲名、演唱者。增加排序显示歌曲列表功能。
      程序设计思路:设置歌单类存放歌曲信息,在测试类中分别使用LinkedList和ArrayList集合存储歌单,调用其类方法实现歌曲的添加,删除,置顶,前移功能。
      问题:直接查找歌曲信息时无法找到
      解决:查找歌曲位置再进行操作

    (三)代码托管

    链接:https://git.oschina.net/hebau_cs15/java-cs02sqrr.git

  • 相关阅读:
    hdoj5327【前缀和思想】
    codeforces 611C
    codeforces 632C
    poj1163 【记忆化搜索·水】
    2016 Multi-University Training Contest 2 A Acperience
    细剖最短路【闲谈,权当是饭后杂文】
    poj1724【最短路】
    [YY题]HDOJ5288 OO’s Sequence
    Codeforces Round #363 (Div. 2) C. Vacations
    POJ2105【进制转化】
  • 原文地址:https://www.cnblogs.com/namtaehyun/p/6790641.html
Copyright © 2011-2022 走看看