关于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();
}
- 关于HaspMap存放顺序的解决问题
- 关于HaspMap的顺序问题
- haspMap的遍历
- 关于解决问题的思考
- 关于解决问题的感想
- hbase数据的存放顺序
- 联合体的存放顺序问题
- java中HaspMap的使用
- 关于CPU字节存放顺序的说明(大端小端)
- 关于字节在内在存放的顺序(Big Endian and Little Endian)
- 关于未解决问题的思考
- YUV内存里的存放顺序
- YUV内存里的存放顺序
- 多字节数据的存放顺序
- 汉字的存放顺序和传输顺序是不一样的
- 关于如何高效的解决问题的探索
- 关于上传漏洞的解决问题 [转]
- 关于论坛求助别人,解决问题的步骤
- 使用127.0.0.1这个地址可以连接上服务端,但是使用本机真实IP(ipconfig)却连不上
- NYOJ 540 奇怪的排序
- IOS7UIToolBar高斯模糊学习
- GIT 4 冲突解决
- DFSClient技术内幕(读取数据)
- 关于HaspMap存放顺序的解决问题
- 笔试题(一)
- DFSClient技术内幕(数据的写入--OutputStream的初始化)
- DFSClient技术内幕(写入数据——管道的建立)
- GIT 5 冲突解决2
- FatMouse' Trade
- winform 加载窗体时弹出另一个窗体并显示进度条的源码
- DFSClient技术内幕(写入数据——数据写入过程)
- 嵌入式开发基础笔记