java作业6

(一)学习总结

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" );
       }
    }
    
运行结果:


把可能会发生错误的代码放进try语句块,并用catch去捕获这个异常。当程序检测到出现了一个错误时会抛出一个异常对象。异常处理代码会捕获并处理这个错误。catch语句块中的代码用于处理错误。当异常发生时,程序控制流程由try语句块跳转到catch语句块。不管是否有异常发生,finally语句块中的语句始终保证被执行。如果没有提供合适的异常处理代码,JVM将会结束掉整个应用程序。

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

程序运行结果:

错误原因:不能再collection接口中将其删除,应该改为it.remove.这是迭代器中的remove方法,使用这种方法当删除一个对象时,他会自动向前挪动一个元素,不会造成指针空指的情况。而collection中的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;
}

(二)实验总结

(1)ktv系统
程序设计思路:使用list接口中的arraylist方法。
问题1:将歌曲置顶操作
问题解决方案: System.out.println("请输入歌名");
String f = input.next();
System.out.println("请输入演唱者");
String g = input.next();
song Song = new song(f, g);

			for (int i = 0; i < ktv.size(); i++) {
				if (f.equals(ktv.get(i).getSong())) {
					song temp = ktv.get(i);

					ktv.remove(i);
					ktv.add(0, temp);

先对列表中的数据进行逐一遍历,如果找到需要置顶的歌曲,在创建一个song对象,把找到的数据存到创建的对象中,然后用remove方法将其删除,操作完成,歌曲置顶。
问题2:歌曲排序的实现。
问题解决方案:
1.用collection接口中的sort方法进行排序。

 Collections.sort(ktv);

2.然后再song这个类中重写compareTo方法。

public int compareTo(song o){
		return this.getSong().compareTo(o.getSong());	
			}

(2)微博注册

1.程序设计思路:创建三个类,一个是用户信息类,一个是信息检验类,一个是测试类,首先在测试类中申请邮箱的账号密码,如果出现信息重复的情况将不能申请,最后将申请的邮箱账号输出。在这道题中,我又加了一项功能,就是用申请的邮箱账号登陆,在登陆的时候,输入账号,密码,如果输入账号密码正确,则登陆成功,如果不正确,系统会提示你什么地方输错了,重新输入。
问题一:利用正则表达式进行判断
对生日进行判断:String Date="\\d{4}-\\d{2}-\\d{2}";
对手机号进行判断:String no="(1)+(3|4|5|8)+\\d{9}";
对邮箱进行判断: String email="\\w+@\\w+.(com|com.cn|cn|net|gov|edu|org)";
问题2:用itertor方法进行输出
应该对iterator.next()进行向上转型,否则他会指向下一个元素。

public int check1(Set<user> user,String name,String phone){
		Iterator<user> iterator = user.iterator();
		int flag=0;
		while(iterator.hasNext()){
			user obj=iterator.next();
			if(obj.getName().equals(name)){
				flag=1;
				System.out.println("该名字已经存在");
			}
			if(obj.getPhone().equals(phone)){
				flag=1;
				System.out.println("手机号已存在");
			}
			
		}
		if(flag==0){
			//System.out.println("注册成功");
			
			return 1;
		}
		else 
			System.out.println("注册失败");
			return 0;
		
		
	}
}

(三)代码托管

链接:
https://git.oschina.net/hebau_cs15/hebau-cs02wzt/tree/master/java作业6?dir=1&filepath=java作业6&oid=8a840d4af47e849c3f44be8eebc07af2f99545a0&sha=90d817024155b2aa886a8009903177a0de8c7519

posted on 2017-05-02 17:25  子腾  阅读(172)  评论(0)    收藏  举报

导航