遍历Map的三种常用方法 java

[size=medium][b]1、一般的map定义:[/b]
Map<Key, Object> map = new HashMap<Key, Object>();
这种map的定义,里面的数据是乱序的,没有顺序规则可依;

[b]2、保持有序的map定义:[/b]
Map<Key, Object> map = new LinkedHashMap<Key, Object>();
链表结构的HashMap,是有序的,put进去的数据顺序是怎样,出来的顺序也是那样,不会打乱里面数据的顺序;
但是需要注意的一点是:如果put进去的key是存在相同值的话, 用LinkedHashMap是会乱序的,而且出来的数据也不对,对于重复值的存储,最好先合并重复的key,再将相应的key和object放进去。
[b]
3、自定义顺序的map定义:[/b]
Map<Key, Object> map = new TreeMap<Key, Object>();
这种map的顺序可自定制,例如倒序:
Map<Key, Object> map = new TreeMap<Key, Object>();
map.descendingKeySet();[/size]


import java.io.UnsupportedEncodingException;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

/**
* @author hpjianhua
*
*/
public class TestUtils {
/**
* @param args
* @throws UnsupportedEncodingException
*/
public static void main(String[] args) throws UnsupportedEncodingException {
Map<String, String> map = new HashMap<String, String>();
//初始化
map.put("A", "米国");
map.put("C", "中国");
map.put("J", "日本");

//第一种遍历方法: 直接遍历Map中的内容Values
Collection values = map.values();
Iterator it1 = values.iterator();
while(it1.hasNext()){
System.out.println(it1.next());
}

//第二种遍历方法: 先拿到Key的Set再根据Key去遍历Value
Set<String> set = map.keySet();
Iterator it2 = set.iterator();
while(it2.hasNext()){
String key = (String)it2.next();
String value = (String) map.get(key);
System.out.println("Key: " + key +" value: " + value);
}

//第三种遍历方法: 用Map的Entry对象去拿,然后再取Key 与Value
Set<Map.Entry<String, String>> setEntry = map.entrySet();
Iterator<Map.Entry<String, String>> it3 = setEntry.iterator();
while(it3.hasNext()){
Map.Entry<String, String> entry = it3.next();
System.out.println(entry.getKey() + " ___ " +entry.getValue());
}

}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值