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" );
}
}
运行结果:
Exception thrown in method3
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)
分析:
getMessage方法输出的是错误信息
printStackTrace方法输出的是异常信息在程序中出错的位置以及原因
异常的传播过程:
try语句中添加可能出现异常的语句,catch语句中可以实例化异常并处理异常。有的语句在运行过程中可能会出现异常,也可以人为地通过throw关键字抛出异常。当异常出现时,我们可以通过try...catch来对异常进行处理,也可以通过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
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输出时由集合对象调用了自身的删除方法,会出现运行时的错误,因为集合本身的内容被破坏掉了,所以会停止输出。
解决方法:
使用Iterator的remove方法进行删除。
修改后
import java.util.*;
public class Demo
{
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(); //使用Iterator的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类中覆写equals方法和hashcode方法
修改后:
import java.util.*;
class Student {
String id;
String name;
public Student(String id, String name) {
this.id = id;
this.name = name;
}
public int hashCode(){ //覆写hashCode
return (this.id.hashCode()+this.name.hashCode());
}
public boolean equals(Object obj){ //覆写equals
if(obj==null){
return false;
}
if(this==obj){
return true;
}
if(obj instanceof Student){
Student stu=(Student)obj;
if(stu.name.equals(this.name)&&stu.id.equals(this.id)){
return true;
}else{
return false;
}
}
return false;
}
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 id=1, name=Jack, Student id=2, name=Rose]
(二)实验总结
实验内容:
1.模拟KTV点歌系统
分别用LinkedList和ArrayList集合,实现一个模拟KTV点歌系统的程序。实现以下功能:
(1)显示歌曲列表
(2)添加歌曲到列表
(3)删除歌曲
(4)将歌曲置顶
(5)将歌曲前移一位
(6)退出
题目扩展:歌曲包括曲名、演唱者。增加排序显示歌曲列表功能。
设计思路:
创建Song类,类中包含歌曲名和歌手名,覆写compareTo方法,在测试类中进行实例化并处理。
问题:
通过Scanner输入的字符串会从空格断开
解决方法:
next()方法默认从空格处断开,使用nextLine()方法可以从换行处断开。
2.模拟微博用户注册
用HashSet实现一个模拟微博用户注册的程序。用户输入用户名、密码、确认密码、生日(格式yyyy-mm-dd)、手机号码(11位,13、15、17、18开头)、邮箱信息进行微博的注###册。要求对用户输入的信息进行验证,输入信息正确后,验证是否重复注册,如果不是则注册成功,否则注册失败。
提示:
(1)设计一个用户类存储用户注册信息
(2)设计一个校验信息类,定义校验方法完成对输入信息的校验。学习使用正则表达式完成对生日、手机号码和邮箱的验证。
(3)设计一个用户注册类模拟注册过程。用HashSet存储用户数据列表,定义一个initData()方法添加初始用户信息。在main方法中完成用户注册功能。
程序设计思路:
设计一个借口定义全局变量,定义个人信息类,储存每个用户的个人信息,设计工厂类实现借口,继承数据,实现实例化。
问题:
某个用户修改密码后不能通过remove方法清除原用户信息。
解决方法:
在个人信息类中覆写euqals方法和hashCode方法后可通过remove清除原用户信息。
(三)代码托管
- 码云commit历史截图
(四)学习进度条
代码行数(新增/累积) | 学习时间(新增/累积) | 本周学习内容 | |
---|---|---|---|
目标 | 5000行 | 300小时 | |
第2-4周 | 300/300 | 15/15 | 学习了用Scanner从控制台输入和随机数的创建和应用 |
第5周 | 500/500 | 25/25 | String和char[]等之间的相互转化 |
第6周 | 550/550 | 35/35 | class类的创建和应用,this关键字,java比较器 |
第7周 | 650/650 | 45/45 | 继承和覆写 |
第8周 | 750/750 | 55/55 | 接口、抽象类、日期类和匿名内部类 |
第9周 | 900/900 | 53/53 | JAVA的异常捕获,List接口和Set接口,迭代器 |