上传者: 44279771
|
上传时间: 2021-06-14 11:28:44
|
文件大小: 498KB
|
文件类型: DOC
掌握集合的概念、体系结构、分类及使用场景
2)了解Set接口及主要实现类(HashSet、TreeSet)
3)了解List接口及主要实现类(ArrayList、LinkedList、Vector)
4)了解Map接口及主要实现类(HashMap、TreeMap、HashTable)
二、实验内容及步骤
1、编写程序练习将以下5个Person类的对象放在一个HashSet中。
姓名:张三 身份证号:178880001
姓名:王五 身份证号:178880002
姓名:李四 身份证号:178880003
姓名:王五 身份证号:178880002
姓名:李四 身份证号:178880004
注意:因为Person类是自定义类,需要重写hashCode()方法和equals()方法,并规定只有姓名和身份证号都相等,则对象相等。
其中计算哈希码的算法:(31 + ((name == null) ? 0 : name.hashCode()))*31 + id
(注:name:Person对象的姓名,id:Person对象的身份证号)
主方法中作如下测试:
1)创建一个可放置Person类对象的HashSet;
2)依次添加上述5个对象到HashSet中;
3)把集合中的元素打印出来(使用迭代器Iterator)
2、编写程序练习List集合的基本使用:
1) 创建一个只能容纳String对象名为names的ArrayList集合;
2)按顺序往集合中添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七";
3)对集合进行遍历,分别打印集合中的每个元素的位置与内容;
4)打印集合的大小,然后删除集合中的第3个元素,并显示删除元素的内容,然后再打印目前集合中第3个元素的内容,并再次打印集合的大小。
3、编写程序练习Map集合的基本使用:
1)创建一个只能容纳String对象的person的HashMap集合;
2)往集合中添加5个"键-值"对象:
"id"-"1"; "name"-"张三"; "sex"-"男"; "age"-"25"; "hobby"-"爱学Java"
3)对集合进行遍历,分别打印集合中的每个元素的键与值;
4)打印集合的大小,然后删除集合中的键为age的元素,并显示删除元素的内容,并再次打印集合的大小。
四、思考题
1、集合中的List、Set、Map有哪些不同?
2、为什么使用集合框架,而尽可能少用数组作为存储结构?
3、如何使用TreeSet实现第一题?