(一)学习总结
1.用思维导图对本周的学习内容进行总结。
参考资料: XMind
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方法:
---printStackTrace方法:
---getMessage方法会获得具体的异常名称,而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);
}
}
---程序的运行结果为:
---删除的是books集合的最后一个对象,运行的结果为:
---原因:删除一个对象时,集合的大小会发生改变,迭代的次数也会发生变化,这就造成了运行结果的错误。
---在遍历时非要删除集合中的元素,应改为:
用迭代器自身的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);
}
}
---原因:HashSet没有依靠Object类的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 != 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点歌系统
分别用LinkedList和ArrayList集合,实现一个模拟KTV点歌系统的程序。实现以下功能:
(1)显示歌曲列表
(2)添加歌曲到列表
(3)删除歌曲
(4)将歌曲置顶
(5)将歌曲前移一位
(6)退出
程序设计思路:分别定义这几个功能的方法,在主方法中进行调用。
问题1:添加歌曲时没有在已有的列表中进行添加
原因:没有传递参数
解决方案:
....
public static void add(List<String>List1){
Collection<String>Collection1=new ArrayList<String>();
Collection1.add("飘扬过海来看你");
List1.addAll(2,Collection1);
System.out.println(List1);
}
...
问题2:置顶时,没有置顶
原因:没有删除以前歌曲的下标
解决方案:
for(int j=0;j<List3.size();j++){
if(name.equals(List3.get(j))){
List3.remove(j);
List3.add(0,name);
}
}
2.模拟微博用户注册
用HashSet实现一个模拟微博用户注册的程序。用户输入用户名、密码、确认密码、生日(格式yyyy-mm-dd)、手机号码(11位,13、15、17、18开头)、邮箱信息进行微博的注册。要求对用户输入的信息进行验证,输入信息正确后,验证是否重复注册,如果不是则注册成功,否则注册失败。
提示:
(1)设计一个用户类存储用户注册信息
(2)设计一个校验信息类,定义校验方法完成对输入信息的校验。学习使用正则表达式完成对生日、手机号码和邮箱的验证。
(3)设计一个用户注册类模拟注册过程。用HashSet存储用户数据列表,定义一个initData()方法添加初始用户信息。在main方法中完成用户注册功能。
程序设计思路:设计一个信息类,再设计一个校验信息类,继承于信息类,在里面定义验证的方法。在主方法中进行测试。
问题1:判断验证那语句存在错误
解决方案:请教同学,进行了完善。
if(n==0){
System.out.println("名字可用");
}else{
System.out.println("名字不可用");
m++;
}
if(ji.mima()) {
System.out.println("密码正确");
} else {
System.out.println("两次密码不相同!");
m++;
}
if(ji.birth()) {
System.out.println("生日格式正确");
} else {
System.out.println("生日格式不正确!");
m++;
}
if(ji.phone()){
System.out.println("手机格式正确");
}else{
System.out.println("手机格式不正确,以13,15,17,18开头的11位!");
m++;
}
if(ji.email()){
System.out.println("邮箱格式合法");
}else{
System.out.println("邮箱格式不合法");
m++;
}
if(m==0){
System.out.println("注册成功!");
zhuce.add(ji);
}else{
System.out.println("注册失败!");
}
(三)代码托管