Fork me on Gitee

Java第六次作业--异常处理和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

而printStackTrace方法输出的是

java.lang.Exception: Exception thrown in method3
at PrintExceptionStack.method3(PrintExceptionStack.java:22)
at PrintExceptionStack.method2(PrintExceptionStack.java:18)
at PrintExceptionStack.method1(PrintExceptionStack.java:14)
at PrintExceptionStack.main(PrintExceptionStack.java:6)

在java程序中产生异常,则会产生一个异常类的实例化对象,在try语句中对此异常对象进行捕捉,然后与catch语句中的各个异常类型进行匹配,如果匹配成功则执行catch语句中的代码。

在 method3()中抛出了一个异常,那么在method2(),method1()中相继调用该方法时也要抛出这个异常,最后在主方法中进行捕获处理,并输出异常信息。

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);
    }
}

运行结果:

原始元素之后:[One book, Two book, Three book]
Exception in thread "main" One book
java.util.ConcurrentModificationException
at java.util.ArrayList$Itr.checkForComodification(ArrayList.java:886)
at java.util.ArrayList$Itr.next(ArrayList.java:836)
at Test.main(Test.java:14)

删除最后一个的运行结果:

原始元素之后:[One book, Two book, Three book]
One book
Exception in thread "main" Two book
Three book
java.util.ConcurrentModificationException
at java.util.ArrayList$Itr.checkForComodification(ArrayList.java:819)
at java.util.ArrayList$Itr.next(ArrayList.java:791)
at Test.main(Test.java:14)

Iterator 在工作的时候是不允许被迭代的对象改变的,使用 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存储的元素是不可重复的。运行下面的程序,分析为什么存入了相同的学生信息?如果要去掉重复元素,应该如何修改程序。

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);                
}
}

原因:要想去掉重复元素,必须进行对象是否重复的判断,HashSet依靠hashCode()方法和equals()方法完成重复元素判断,因此需覆写 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 ;
}
public int hashCode() {
    final int p = 10;
    int t = 1;
    t = p * t + ((id == null) ? 0 : id.hashCode());
    t = p * t + ((name == null) ? 0 : name.hashCode());
    return t;
}
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.实验内容:

1.模拟KTV点歌系统

分别用LinkedList和ArrayList集合,实现一个模拟KTV点歌系统的程序。实现以下功能:

(1)显示歌曲列表

(2)添加歌曲到列表

(3)删除歌曲

(4)将歌曲置顶

(5)将歌曲前移一位

(6)退出

程序设计思路:创建一个String类的LinkedList或ArrayList,使用switch...case方法,添加数据,输入歌曲名字进行删除,置顶,前移歌曲的操作。

2.模拟微博用户注册
用HashSet实现一个模拟微博用户注册的程序。用户输入用户名、密码、确认密码、生日(格式yyyy-mm-dd)、手机号码(11位,13、15、17、18开头)、邮箱信息进行微博的注册。要求对用户输入的信息进行验证,输入信息正确后,验证是否重复注册,如果不是则注册成功,否则注册失败。

提示:

(1)设计一个用户类存储用户注册信息

(2)设计一个校验信息类,定义校验方法完成对输入信息的校验。学习使用正则表达式完成对生日、手机号码和邮箱的验证。

(3)设计一个用户注册类模拟注册过程。用HashSet存储用户数据列表,定义一个initData()方法添加初始用户信息。在main方法中完成用户注册功能。

程序设计思路:创建Use类用来判断用户输入的是否正确,创建User类实现get和set方法,并添加hashCode方法删除重复的元素,创建Weibo类存储数据,在Test类中进行输入操作。

(三)代码托管

作业链接

posted @ 2017-05-04 19:24  明叶师兄。  阅读(568)  评论(0编辑  收藏  举报