JAVA-TreeMap的应用例子.

数据结构一直,用法类似:HasMap->HashSet,TreeMap->TreeSet

<wbr></wbr>

Map:存入键值对,同时要保证键的唯一性.
<wbr>|--HashMap: 采用哈希表数据结构.判断重复元素需要覆盖hashCode、equals方法,HashSet由HashMap得来.<br><wbr><wbr><wbr><wbr>线程不安全,可以存放null键、null值.<br><wbr>|--HashTable:数据结构同样是哈希表,线程安全,不可以存放null键、null值,效率低,被HashMap取代.<br><wbr>|--TreeMap: 采用二叉树数据结构.可以对TreeMap集合中的键进行排序.<br><wbr><br><wbr>※注意:1、区分HashMap、HashTable的区别:线程安全性不同,是否可以存放null值,效率.<br><wbr><wbr><wbr>2、</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

Map集合取出元素的原理:
<wbr>先将Map转成Set集合,然后对Set集合进行迭代.<br><wbr>keySet:将所有的键取出放在Set集合中,在根据Set集合得到的key值取出value值.<br><wbr>entrySet:将键值的关系取出存入Set集合,监制关系有自己的类型,为Map接口中定<br><wbr><wbr><wbr> 义的静态接口Map.Entry.可以通过getKey(),getValue()方法取值,</wbr></wbr></wbr></wbr></wbr></wbr>

什么时候使用Map集合?
————当出现了对象之间存在映射关系时,就需要使用Map集合.

import java.util.*;
class TreeMapDemo
{
<wbr>public static void main(String[] args)<br><wbr>{<br><wbr><wbr>TreeMap&lt;Student, String&gt; hm = new TreeMap&lt;Student, String&gt;(<br><wbr><wbr>new Comparator&lt;Student&gt;()<br><wbr><wbr>{<br><wbr><wbr><wbr>public int compare(Student st1, Student st2)<br><wbr><wbr><wbr>{<br><wbr><wbr><wbr><wbr>if (st1.getAge() &gt; st2.getAge())<br><wbr><wbr><wbr><wbr><wbr>return 1;<br><wbr><wbr><wbr><wbr>else if (st1.getAge() == st2.getAge())<br><wbr><wbr><wbr><wbr><wbr>return st1.getName().compareTo(st2.getName());<br><wbr><wbr><wbr><wbr>return -1;<br><wbr><wbr><wbr>}<br><wbr><wbr>});<br><wbr><wbr><br><wbr><wbr>hm.put(new Student("张三", 20), "北京");<br><wbr><wbr>hm.put(new Student("李四", 21), "西安");<br><wbr><wbr>hm.put(new Student("王五", 15), "重庆");<br><wbr><wbr>hm.put(new Student("赵六", 26), "成都");<br><wbr><wbr>hm.put(new Student("孙悦", 25), null);<wbr><wbr> //HashMap可以存null值,而HashTable不可以,因此,不能用get方法返回null来判断键值是否存在,而应该用containsKey方法判断.<br><wbr><wbr>//注意:put方法有返回值,返回的是键值对应关系的值,集合中原来对键值没有指定关系,返回null,有则返回原来的值.<br><wbr><wbr>String a = hm.put(new Student("小七", 12), "绵阳");<wbr><wbr> //原来集合中没有对键值(new Student("小七", 12))指定关系,返回为null<br><wbr><wbr>//hm.put(new Student("小七", 12), "绵阳"); //未覆盖hashCode方法和equals方法时,能够存入相同的元素.<br><wbr><wbr>String b = hm.put(new Student("小七", 12), "太原"); //原来对该键值(new Student("小七", 12))指定了对应关系,返回原来已经指定的值.而这里的太原覆盖了原来的绵阳.<br><wbr><wbr>System.out.println(a + ".." + b);</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr><wbr>Set &lt;Map.Entry&lt;Student, String&gt;&gt; s = hm.entrySet();<br><wbr><wbr>for (Iterator&lt;Map.Entry&lt;Student, String&gt;&gt; it = s.iterator(); it.hasNext(); )<br><wbr><wbr>{<br><wbr><wbr><wbr>Map.Entry&lt;Student, String&gt; me = it.next();<br><wbr><wbr><wbr>Student stu = me.getKey();<br><wbr><wbr><wbr>String addr = me.getValue();<br><wbr><wbr><wbr>System.out.println(stu.getName() + ".." + stu.getAge() + ".." + addr);<br><wbr><wbr>}<wbr><wbr><br><wbr>}<br> }</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

class Student
{
<wbr>private String name;<br><wbr>private int age;<br><wbr>Student(String name, int age)<br><wbr>{<br><wbr><wbr>this.name = name;<br><wbr><wbr>this.age<wbr> = age;<br><wbr>}</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr>public String getName()<br><wbr>{<br><wbr><wbr>return name;<br><wbr>}<br><wbr>public int getAge()<br><wbr>{<br><wbr><wbr>return age;<br><wbr>}</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr>public int hashCode()<wbr> //注意,判断HashSet、HashMap集合的唯一性,覆盖hashCode和equals方法,而TreeMap、TreeMap排序实现comparable或comparator接口.<br><wbr>{<br><wbr><wbr>return name.hashCode() + age*29;<br><wbr>}</wbr></wbr></wbr></wbr></wbr></wbr>

<wbr>public boolean equals(Object obj)<br><wbr>{<br><wbr><wbr>if (!(obj instanceof Student))<br><wbr><wbr><wbr>return false;<br><wbr><wbr>Student student = (Student)obj;<br><wbr><wbr>return this.name.equals(student.name) &amp;&amp; this.age == student.age;<wbr><wbr><br><wbr>}</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

<wbr>public String toString()<br><wbr>{<br><wbr><wbr>return name + ".." + age;<br><wbr>}<br> }<br></wbr></wbr></wbr></wbr></wbr>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值