这世上有三样东西是别人抢不走的:一是吃进胃里的食物,二是藏在心中的梦想,三是读进大脑的书。

《Java技术》第六次作业计科1501赵健宇

(一)学习总结

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 st atic void method3() throws Exception {
		throw new Exception("Exception thrown in method3");
	}
}

显示结果:

  • printStackTrace方法的运行结果输出的是异常信息与出现异常的位置:

    java.lang.Exception: Exception thrown in method3
    at excise.PrintExceptionStack.method3(PrintExceptionStack.java:28)
    at excise.PrintExceptionStack.method2(PrintExceptionStack.java:24)
    at excise.PrintExceptionStack.method1(PrintExceptionStack.java:20)
    at excise.PrintExceptionStack.main(PrintExceptionStack.java:6)

  • getMessage方法只会获得具体的异常名称. 比如说NullPoint 空指针,就告诉你说是空指针:

    Exception thrown in method3

处理顺序:
当程序检测到出现了一个错误时会抛出一个异常对象。异常处理代码会捕获并处理这个错误。catch语句块中的代码用于处理错误。当异常发生时,程序控制流程由try语句块跳转到catch语句块。不管是否有异常发生,finally语句块中的语句始终保证被执行。如果没有提供合适的异常处理代码,JVM将会结束掉整个应用程序。
Throws关键字,不管是否有异常,在调用此方法都必须进行异常处理

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]
One book
原因:在程序运行中,内容确实删除了,但是迭代输出在内容删除之后就停止了,因为集合本身的内容被破坏掉,迭代出现错误。
解决办法:使用迭代器进行删除。

it.remove();

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

原因:添加的匿名对象,他们引用的地址不同
解决办法:复写object类里面的equals和hashcode

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

5.其他需要总结的内容。

Java list的用法排序及遍历

(二)实验总结

实验内容:

1.模拟KTV点歌系统

分别用LinkedList和ArrayList集合,实现一个模拟KTV点歌系统的程序。实现以下功能:
(1)显示歌曲列表
(2)添加歌曲到列表
(3)删除歌曲
(4)将歌曲置顶
(5)将歌曲前移一位
(6)退出
题目扩展:歌曲包括曲名、演唱者。增加排序显示歌曲列表功能。
程序设计思路:分别使用linklist,arrayslist集合。创建Music类保存歌曲名演唱者,创建ktvsystem类写static方法用类名直接调用
问题1:Music类的对象排序问题
解决方案:使用java.util.comparator继承这个接口

2.模拟微博用户注册

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

程序设计思路:分别创建三个类。使用正则表达式校验用户信息
问题1:用户名存在问题
解决方案:使用迭代,设置一个flag标记是否已经存在。

(三)代码托管(务必链接到你的项目)

点击此处进入码云

posted @ 2017-05-03 20:21  进击的小白V  阅读(254)  评论(0编辑  收藏  举报
感谢观看。转载复制请注明源处~!