最近在做一个项目时,有一个程序需要通过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();
}