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

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

运行的结果为

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

原因:e.getMessage(); 只会获得具体的异常名称. 比如说NullPoint 空指针,就告诉你说是空指针...

e.printStackTrace();会打出详细异常,异常名称,出错位置,便于调试用..
一般一个异常至少几十行

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

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;


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

原因:此时应该利用迭代器的删除进行处理,更改成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);                
    }
}

原因为:
Set接口不允许存放重复元素。要求呢必须是统一对象,何为统一对象,就是内存中的编码相同。
为什么要重写equals方法和hashCode方法(技术实现原理):
程序向HashSet中添加一个对象时,先用hashCode方法计算出该对象的哈希码。
比较:
Set接口不允许存放重复元素。HashSet依靠Object类的hashCode()方法和equals()方法完成重复元素的判断。
hashCode():先判断对象的哈希码是否相同,依靠哈希码取出对象的内容。
equals():将对象的属性依次比较
所以,加入HashSet中的元素所属类必须重写hashCode()方法和equals()方法以确保对象的唯一性。

重写hashcode()方法和equals()方法

public boolean equals(Object obj){
            if(this==obj){
                return true;
            }
            if(!(obj instanceof Student)){
                return false;    
            }
			if(obj==null){
				return false;
			}
            Student s=(Student) obj;
            if(this.name.equals(s.name)&&this.id.equals(s.id)){
                return true;
            }else{
                return false;
            }
        }
        public int hashCode(){
            int finall;
            Student input=(Student) this;
            if(!input.id.equals(null)){
                return finall=input.id.hashCode()+input.name.hashCode();
            }
            else
                {return 0;
                }
        }
    }

(二)实验总结#


1.模拟KTV点歌系统
分别用LinkedList和ArrayList集合,实现一个模拟KTV点歌系统的程序。实现以下功能:
(1)显示歌曲列表
(2)添加歌曲到列表
(3)删除歌曲
(4)将歌曲置顶
(5)将歌曲前移一位
(6)退出
程序设计思路:分别建立LinkedList和ArrayList集合,其中就是置顶的原理就是,首先删除第一个位置的内容,之后把第一的位置设置成要置顶的内容的数据,之后再重新添加一个就是之前所删除的内容。


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

程序设计思路:分别建立三个类,分别是员工类还有验证类还有一个主要的测试类,主要还是利用的是正则表达式的知识,其中还有hashcode的知识不能为空,equals的方法进行重写比较的时候。等等


码云截图#

码云链接:#

https://git.oschina.net/hebau_cs15/hebau-cs01jhr.git##