1.在HashSet集合中添加三个Person对象,把姓名相同的人当做同一个人,禁止重复添加。要求如下:
Person类中定义name和age属性,重写hashCode()方法和equals()方法,针对 Person类的name属性进行比较,如果name相同,hashCode()方法的返回值相同,equals()方法返回true。
package item6;
import java.util.*;
/**
* 把姓名相同的人当做同一个人
* @author Rabbit
*
*/
class Person{
private String name;
private int age;
public Person(String name,int age) {
this.name=name;
this.age=age;
}
public String toString() {
return name+":"+age;
}
public int hashCode() {
return name.hashCode();
}
public boolean equals(Object obj) {
if(this==obj) {
return true;
}
if(!(obj instanceof Person)) {
return false;
}
Person stu=(Person) obj;
boolean b=this.name.equals(stu.name);
return b;
}
}
public class Main3 {
@SuppressWarnings("unchecked")
public static void main(String[] args) {
@SuppressWarnings("rawtypes")
HashSet hs=new HashSet();
Person s1=new Person("Jack",19);
Person s2=new Person("Jack",29);
Person s3=new Person("Rose",25);
hs.add(s1);
hs.add(s2);
hs.add(s3);
System.out.println(hs);
}
}
2.选择合适的Map集合保存5位学员的学号和姓名,然后按学号的自然顺序的倒序将这些键值对一一打印出来。
提示:
1)创建TreeMap集合。
2)使用put()方法将学号(“1”、“2”、“3”、“4”、“5”)和姓名(“Lucy”、“John”、“Smith”、“Aimee”、“Amanda”)存储到Map中,存的时候可以打乱顺序观察排序后的效果。
3)使用 map.keySet()获取键的Set集合。
4)使用Set集合的iterator()方法获得Iterator对象用于迭代键。
5)使用Map集合的get()方法获取键所对应的值。
package item6;
/**
* 选择合适的Map集合保存学员的学号和和姓名,按照学号倒序排序
* @author Rabbit
*
*/
import java.util.*;
@SuppressWarnings("rawtypes")
class MyComparator implements Comparator{
public int compare(Object obj1,Object obj2) {
String s1=(String) obj1;
String s2=(String) obj2;
return s2.compareTo(s1);
}
}
public class Main4 {
@SuppressWarnings({ "rawtypes", "unchecked" })
public static void main(String[] args) {
TreeMap map=new TreeMap(new MyComparator());
map.put("2", "John");
map.put("1", "Lucy");
map.put("5", "Amada");
map.put("3", "Smith");
map.put("4", "Aimee");
Set keySet=map.keySet(); //获取Set集合
Iterator it=keySet.iterator();//Iterator迭代器
while(it.hasNext()) {
Object key=it.next();
Object value=map.get(key);
System.out.println(key+":"+value);
}
}
}