java map练习
来源:互联网 发布:ember.js 中文api 编辑:程序博客网 时间:2024/04/27 18:41
/*
每一个学生都有对应的归属地。
学生Student,地址String。
学生属性:姓名,年龄。
注意:姓名和年龄相同的视为同一个学生。
保证学生的唯一性。
1,描述学生。
2,定义map容器。将学生作为键,地址作为值。存入。
3,获取map集合中的元素。
*/
import java.util.*;
class Student implements Comparable<Student>
{
private String name;
private int age;
Student(String name,int age)
{
this.name = name;
this.age = age;
}
public int compareTo(Student s)
{
int num = new Integer(this.age).compareTo(new Integer(s.age));
if(num==0)
return this.name.compareTo(s.name);
return num;
}
public int hashCode()
{
return name.hashCode()+age*34;
}
public boolean equals(Object obj)
{
if(!(obj instanceof Student))
throw new ClassCastException("类型不匹配");
Student s = (Student)obj;
return this.name.equals(s.name) && this.age==s.age;
}
public String getName()
{
return name;
}
public int getAge()
{
return age;
}
public String toString()
{
return name+":"+age;
}
}
class MapTest
{
public static void main(String[] args)
{
HashMap<Student,String> hm = new HashMap<Student,String>();
hm.put(new Student("lisi1",21),"beijing");
hm.put(new Student("lisi1",21),"tianjin");
hm.put(new Student("lisi2",22),"shanghai");
hm.put(new Student("lisi3",23),"nanjing");
hm.put(new Student("lisi4",24),"wuhan");
//第一种取出方式 keySet
Set<Student> keySet = hm.keySet();
Iterator<Student> it = keySet.iterator();
while(it.hasNext())
{
Student stu = it.next();
String addr = hm.get(stu);
System.out.println(stu+".."+addr);
}
//第二种取出方式 entrySet
Set<Map.Entry<Student,String>> entrySet = hm.entrySet();
Iterator<Map.Entry<Student,String>> iter = entrySet.iterator();
while(iter.hasNext())
{
Map.Entry<Student,String> me = iter.next();
Student stu = me.getKey();
String addr = me.getValue();
System.out.println(stu+"........."+addr);
}
}
}
- java Map练习(一)
- java map练习
- java Map集合练习
- java Map-HashMap、TreeMap练习
- java Map扩展知识练习
- JAVA的map集合练习
- Java Map练习与实际应用
- Java Map接口练习(Map和List及排序)
- Map练习!!!
- Map练习
- Map练习
- (转)Java里的list,set,map操作方法(练习)
- Java里的list,set,map操作方法(练习)
- java例程练习(List,set,map的遍历)
- java map练习之统计单词出现的次数
- java map练习之统计单词出现的次数
- Java——Math,Set,List,map相关练习
- Map容器练习
- STM32中DMA的认识
- PHP多条件查询
- 为什么使用<!DOCTYPE HTML>
- Qt那点事儿(一)
- ZOJ 2386 Ultra-QuickSort(逆序数)
- java map练习
- 总结:windows跟linux的一些对比
- 轻快的VIM(三):删除
- 使用Win32 API函数实现vc和arduino简单串口通信
- 聊天服务器
- CLR(字符、字符串和文本处理)
- C#中在函数参数列表中第一个参数指定为this有什么用?
- 实验六 二叉树的递归遍历及其应用
- hdu 1242——Rescue(BFS)