Map集合HashMap TreeMap的输出方法

Map集合HashMap TreeMap的输出方法

    【尊重原创,转载请注明出处http://blog.csdn.net/guyuealian/article/details/51934301
集合的输出方式:
     Collection、Set集合中的内容可以通过toArray()方法转换为对象数组输出,而List的可以使用get方法输出。集合类有四种输出方式:
(1)Iterator:迭代输出;集合类的标准输出形式,也是用的最多的(从前向后单向输出)
(2)ListIterator:是Iterator的子接口,专门用于输出List中内容;(使用hasNext和hasPrevious,实现双向迭代输出)
(3)Foreach:For循环遍历语句;
(4)Enumeration:是一个旧的接口,功能与Iterator类似
一、Map集合的遍历输出方式:
   public Set<Map.Entry<K,V>> entrySet():将Map对象变为Set集合
   public Set<K> keySet():以set的形式返回Map集合中所有key
   public Collection<V> values():取得Map集合中所有value
(1)使用keySet和values方法:
[java] view plain copy
  1. Map<Integer, Integer> map = new HashMap<Integer, Integer>();  
  2. //遍历map中的键  
  3. for (Integer key : map.keySet()) {  
  4.     System.out.println("Key = " + key);  
  5. }  
[java] view plain copy
  1. //遍历map中的值  
  2. for (Integer value : map.values()) {  
  3.     System.out.println("Value = " + value);  
  4. }  
(2)使用Map.EntrySet
第一种:使用keySet()和迭代器iterator()该方法,该方法 效率比较低
Map map = new HashMap(); 
Iterator iter = map.keySet().iterator(); //先获得所有key,再用迭代器遍历输出
while (iter.hasNext()) { 
    Object key = iter.next(); 
    Object val = map.get(key); 
} 
第二种: 使用Map.Entry,该方法效率比较高
<span style="color:#006600;">Map map = new HashMap(); 
Iterator iter = map.entrySet().iterator(); 
while (iter.hasNext()) { 
    Map.Entry entry = (Map.Entry) iter.next(); 
    Object key = entry.getKey(); 
    Object val = entry.getValue(); 
} 
     Map.entrySet() 这个方法返回的是一个Set<Map.Entry<K,V>>,Map.Entry 是一个接口,他的用途是表示一个映射项(里面有Key和Value),而Set<Map.Entry<K,V>>表示一个映射项的Set。 Map.Entry里有相应的 getKey和getValue方法 ,让我们能够从一个项中取出Key和Value。这样就能理解了例子中的写法了。
[java] view plain copy
  1. for(Map.Entry me : m.entrySet()) {  
  2.     t.append(me.getKey() + ": " + me.getValue() + "/n");  
  3. }  
    这里的t是一个TextArea,m是一个HashMap。
    这种遍历Map的方法可以让我们在从Map中取得关键字之后,我们不用每次重复返回到Map中取得相对的值。相应的例子如下:
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
public class JavaTest {
	public static void main(String[] args) {
		Map<String, String> map = new HashMap<String, String>();
		map.put("1", "张三");
		map.put("2", "李四");
		map.put("3", "王五");
		/* 方法一 :迭代程序 */
		System.out.println("方法一:");
		Iterator iterator = map.entrySet().iterator();
		while (iterator.hasNext()) {
			Map.Entry<String, String> entry = (Entry<String, String>) iterator
					.next();
			System.out.println("key:" + entry.getKey() + " value"
					+ entry.getValue());
		}
		/* 方法二 */
		System.out.println("方法二:");
		for (Map.Entry<String, String> m : map.entrySet()) {
			System.out.println("key:" + m.getKey() + " value" + m.getValue());
		}
	}
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI吃大瓜

尊重原创,感谢支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值