java第六次作业

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" );//抛出异常
   }
}

运行结果:

printStackTrace方法的输出结果:

getMessage 方法的输出结果:

异常传播过程:
用异常处理的统一出口方法捕获处理异常

try {
  //常规的代码;
}
catch()
{ //处理异常 }
finally {
  //不论发生什么异常(或者不发生任何异常),都要执行的部分;
}

调用method1()抛出异常,method1()调用method2()抛出异常,method3(),抛出异常"Exception thrown in method3"

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

运行结果:

错误原因:
实例化lterator接口时设置的当前元素是it,所以在删除当前元素时应该是it.remove();集合要把内容交给literator输出,在集合的删除操作中也应该存在这个集合的remove()方法。
改正后运行结果:

删除books集合的最后一个对象,运行的结果:

解析:
使用if语句equals()方法对最后一个对象的内容进行判断,并进行删除。
实现方法:
如果使用remove()方法进行删除时,必须重写equals()方法。使用if语句equals()方法对对象的内容进行比较判断,并进行删除。
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);                
    }
}

原因:
存储的内容相同,源空间位置不同,所以"2","Rose"的内容重复。若要改正的话,则需要覆写Object类中的equals()方法和HashCode()方法共同配合才能去掉重复元素。
程序改正:

import java.util.*;
    class Student {
        String id;  
        String name;
        public Student(String id, String name) {
            this.id = id;
            this.name = name;
        }
        public boolean equals(Object obj){//覆写equals()方法
        	if(this==obj){//地址相等
        		return true;//是同一个对象
        	}
        	if(!(obj instanceof Student)){//传递进来的不是本类的对象
        		return false;//不是同一个对象
        	}
        	Student p=(Student)obj;//向下转型
        	if(this.id.equals(p.id)&&this.name==p.name){//属性依次比较
        		return true;//全部属性相等,是同一个对象
        	}else{
        		return false;//全部属性不相等,不是同一个对象
        	}
        }
        public int hashCode()//覆写hashCode方法
        {
        	return this.name.hashCode();//指定编码公式
        }
        public String toString() {//覆写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);                
        }
    }

运行结果:

5.其他需要总结的内容。
1.Collections 类
集合工具类。一般使用迭代输出:lterator接口:
实例化List接口:
listall=new ArraysList();
直接实例化Literator接口:
literatoriter=all.literator();
a:
可以返回空的List,Set,Map集合,但是通过这种方式返回的对象是无法增加数据的不能实现add()方法。
b:
为集合增加内容:
Collections.addAll(all,"内容","内容");
c:
反转集合中的内容:
Collections.reverse(all);//内容反转保存
d:
检索内容:
int point=Collections.binarySearch(all,"内容");
检索结果显示的是其位置point,若无此内容则返回-1.
e:
替换集合中的内容:
Collections.replaceAll(all,"内容","内容");
f:
集合排序:
Collections.sort(all);
g:
交换指定位置的内容:
Collections.swap(all,1,4);//。交换位置1和位置4的内容。

2.Arrays 类:
数组的操作类,主要是实现数组元素的查找,数组内容的填充,检索和排序等功能。
首先声明一个整型数组
int temp[]={1,7,2,3,6,4};
实现数组的排序功能:
Arrays.sort(temp);
以字符串输出数组:
System.out.println(Arrays.toString(temp));
对数据位置进行检索:
int point =Arrays.binarySearch(temp,2)//检索元素2的位置
System.out.println("元素2的位置是:"+point);
填充数组:
Arrays.fill(temp,0);
填充后以字符串输出数组的所有位置上的数组都是0.

(二)实验总结

实验内容:
1.模拟KTV点歌系统
分别用LinkedList和ArrayList集合,实现一个模拟KTV点歌系统的程序。实现以下功能:

(1)显示歌曲列表
(2)添加歌曲到列表

使用Collections类为集合添加内容:

 Collections.addAll(all,"喜洋洋与灰太狼","萝卜啊","桃花朵朵开");//增加内容

(3)删除歌曲
使用hasNext()和equals()方法进行对内容的删除remove()。

while(iter.hasNext())
      {   
    	  String str =iter.next();
          System.out.println(iter);
          if (str.equals("喜洋洋与灰太狼"))
          {
             iter.remove();
          }
      }

(4)将歌曲置顶
(5)将歌曲前移一位
(6)退出
题目扩展:歌曲包括曲名、演唱者。增加排序显示歌曲列表功能。
2.模拟微博用户注册
用HashSet实现一个模拟微博用户注册的程序。用户输入用户名、密码、确认密码、生日(格式yyyy-mm-dd)、手机号码(11位,13、15、17、18开头)、邮箱信息进行微博的注册。要求对用户输入的信息进行验证,输入信息正确后,验证是否重复注册,如果不是则注册成功,否则注册失败。
提示:
(1)设计一个用户类存储用户注册信息
(2)设计一个校验信息类,定义校验方法完成对输入信息的校验。学习使用正则表达式完成对生日、手机号码和邮箱的验证。
(3)设计一个用户注册类模拟注册过程。用HashSet存储用户数据列表,定义一个initData()方法添加初始用户信息。在main方法中完成用户注册功能。

(三)代码托管(务必链接到你的项目)
码云commit历史截图
上传实验项目代码到码云,在码云项目中选择“统计-commits”,设置搜索时间段,搜索本周提交历史,并截图。

https://git.oschina.net/hebau_cs15/java-cs02zt06.git

posted @ 2017-05-04 16:46  彪悍一只猫  阅读(202)  评论(0编辑  收藏  举报