java第六次作业
《Java技术》第六次作业
(一)学习总结
1.
2.当程序中出现异常时,JVM会依据方法调用顺序依次查找有关的错误处理程序。可使用printStackTrace 和getMessage方法了解异常发生的情况。阅读下面的程序,说明printStackTrace方法和getMessage 方法的输出结果分别是什么?并分析异常的传播过程。
getMessage输出结果
java.lang.Exception: Exception thrown in method3
printStackTrace输出结果
at test.Test.method3(Test.java:22)
at test.Test.method2(Test.java:18)
at test.Test.method1(Test.java:14)
at test.Test.main(Test.java:6)
异常的传播过程
把可能会发生错误的代码放进try语句块中,catch语句块捕获这个异常;
执行catch语句块:e.printStackTrace()(在命令行打印异常信息在程序中出错的位置及原因)
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)
删除最后一个对象运行结果:
原始元素之后:[One book, Two book]
One book
移除元素之后:[Two book]
如果删除的是最后一个对象,遍历输出时迭代器的size没有发生改变,所以列表中的内容能够正常输出;当对最后一个对象进行删除时,迭代器的size发生变化,产生异常.
错误原因:如果在对一个列表进行遍历时,将其中的元素删除,迭代器的size会发生改变
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);
}
}
两个相同信息的对象添加时,分别进行实例化,两个对象的HashCode值不同,所以HashSet判断为不同元素
如果HashSet中的元素为自定义的类,须重写hashCode()方法和equals()方法
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;
(二)实验总结
1.KTV系统
- 程序设计思路:创建KTV类存储歌曲信息,创建ArrayList对象
- 实验问题分析:
问题1:菜单的设置
原因:switch用法
2.微博注册系统
程序设计思路
设计一个users类,存储用户的用户名、密码、生日、手机号、邮箱等属性;
设计一个check 检校信息类,包含judje方法,判断用户输入信息是否合法;check方法判断用户名、手机号、邮箱是否重复注册;
设计一个用户注册类,执行用户注册过程:用户输入各项信息后,判断信息是否合法、是否重复,如果信息合格,则注册成功,用户信息添加到HashSet类集中。
(三)代码托管
- 码云commit历史截图