JAVA第六次作业

《Java技术》第六次作业

(一)学习总结

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方法输出结果:

 Exception thrown in method3

printStackTrace方法输出结果:

java.lang.Exception: Exception thrown in method3
	at lianxi.Test.method3(Test.java:22)
	at lianxi.Test.method2(Test.java:18)
	at lianxi.Test.method1(Test.java:14)
	at lianxi.Test.main(Test.java:6)

异常的传播过程:

程序产生异常,一个异常类的实例化对象产生,在try语句对异常对象进行捕捉,产生的异常对象与catch语句中的各个异常类型进行匹配,匹配成功,执行catch语句中的代码。

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集合的最后一个对象,运行的结果:

      原始元素之后:[One book, Two book, Three book]
      One book
      Two book
      Three book
      Exception in thread "main" java.util.ConcurrentModificationException
      	at java.util.ArrayList$Itr.checkForComodification(ArrayList.java:81)
      at java.util.ArrayList$Itr.next(ArrayList.java:791)
      	at lianxi.Test.main(Test.java:16)
    

    原因:如果删除的是最后一个对象,遍历输出时迭代器的大小没有发生改变,所以列表中的内容能够正常输出;当对最后一个对象进行删除时,迭代器的大小发生变化,产生异常

  • 删除集合中的元素:

        while(it.hasNext())
        {
            String book = (String)it.next();
            System.out.println(book);
            if (book.equals("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);                
    }
}
  • 分析:添加对象时,相同信息的对象哈希值不同,所以计算出的存储位置也不同。

  • 修改:覆写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;
      	}
    

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

(二)实验总结

实验内容:
1.模拟KTV点歌系统

  • 程序设计思路:设计一个Sing类,定义歌曲名和演唱者,设计Test类,在Test类里定义题目要求的方法并输出。

  • 实验问题分析:
    问题1:不会将歌曲置顶。
    解决方案:先将要置顶的歌曲删除,再将该歌曲添加到指定位置

     names.remove(new Sing(song3,singer3));
     names.add(0,new Sing(song3,singer3));
    

    问题2:不会将歌曲前移一位。
    解决方案:使用循环,将要前移的歌曲与它前一位的歌曲进行交换。

     String song4=input.next();
     String singer4=input.next();
     for(int i=0;i<names.size();i++){
     	     if(song4.equals(names.get(i).getName())&&singer4.equals(names.get(i).getSinger())){
     	        	 Sing temp=names.get(i-1); 
     	        	 names.set(i-1,names.get(i));
     	        	 names.set(i,temp);	 
     	         }  
     }
    

2.模拟微博用户注册

  • 程序设计思路:
  • 设计一个用户类存储用户注册的信息。
  • 设计一个校验类,定义对用户名,生日,手机号,邮箱的验证方法。
  • 设计一个测试类,输入用户注册信息,并调用校验类里的方法进行验证。
  • 实验问题分析:
    问题1:输入的用户信息出现错误,但是还会被存储进用户注册信息中
    原因:存储用户的注册信息存储的就是用户输入的信息,不管用户输入什么信息,都会被存储进去。
    解决方案:在输错信息之后,应添加一些语句,使其能再输入一次正确的信息,这样存储进用户注册信息中的就是正确的信息了。

      System.out.println("用户名重复");
      System.out.println("请重新输入用户名");
      str1 = input.next();
    

    问题2:在校验类里写方法时,只能在方法里输出,不会在测试类里输出。
    解决方案:使用Boolean函数,确定返回值,在测试类里调用方法时使其等于该返回值。
    校验类:

      boolean f = true;
      		Iterator<User> iterator = allSet.iterator();
      		while(iterator.hasNext()){
      			User user = iterator.next();
      			if(user.getName().equals(st1)){
      				f =  false;
      			}			
      		}
      		return f;
    

测试类:

    System.out.println("请输入用户名");
    	String str1=input.next();	
		if(jiaoyan.Name(allSet, str1) == false){
            System.out.println("用户名重复");
    		System.out.println("请重新输入用户名");
    		str1 = input.next();
		}

(三)代码托管

  • 码云commit历史截图
posted @ 2017-05-04 17:26  luhan1  阅读(137)  评论(0编辑  收藏  举报