关于HaspMap存放顺序的解决问题

来源:互联网 发布:有人转让我的淘宝店铺 编辑:程序博客网 时间:2024/05/22 14:54

最近在做一个项目时,有一个程序需要通过HaspMap来传递参数,而且接收参数的方法对Map中的参数顺序敏感。

所以一开始调试的时候没有注意到HashMap是无序的,就是和你set的顺序无关的,所以程序出现了Bug,后来使用LinkedHaspMap替代了HaspMap就解决了。

 

1. HashMap好像不能排序?不能排,能排的话,哈希算法也就没有意义了.就是要把这些值散列开才爽啊。如果要排序, 请用TreeMap

2.HashMap岂止不能排序!就算你把排好序的元素依次放进HashMap、过段时间其次序会随机变乱的。 
3. HashMap不能保证元素顺序、遇到虚拟机不定时的整理内存堆肯定会把其次序打乱、只能保证元素不会丢。

This class makes no guarantees as to the order of the map。

in particular, it does not guarantee that the order will remain constant

over time.(jdk1.4.2/java.Util.HashMap)

 

HashMap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度。HashMap最多只允许一条记录的键为Null;允许多条记录的值为Null;HashMap不支持线程的同步,即任一时刻可以有多个线程同时写HashMap;可能会导致数据的不一致。如果需要同步,可以用Collections的synchronizedMap方法使HashMap具有同步的能力。LinkedHashMap LinkedHashMap也是一个HashMap,但是内部维持了一个双向链表,可以保持顺序TreeMap 不仅可以保持顺序,而且可以用于排序。

 

顺便也放个常用的MAP遍历在这:

 

Map<String,String[]> paraMap = new HaspMap<String,String[]>();

for (Entry<String ,String[]>entry : paraMap.entrySet())

{

String filedID = entry.getKey();

String[] values = entry.getValue();

}

0 0
原创粉丝点击