Map.Entry 类使用简介,为Map中值排序的方法

使用Map.Entry类,可以同时得到键和值的信息。

先看标准的Map访问方法如下:

Set keys = map.keySet( );
		if(keys != null) {
			Iterator iterator = keys.iterator( );
			while(iterator.hasNext( )) {
				Object key = iterator.next( );
				Object value = map.get(key);
				....;
			}
		}

然后,这个方法有一个问题。从Map中取得关键字之后,我们必须每次重复返回到Map中取得相对的值,这是很繁琐和费时的。

幸运的是,这里有一个更加简单的途径。Map类提供了一个称为entrySet()的方法,这个方法返回一个Map.Entry实例化后的对象集。接着,Map.Entry类提供了一个getKey()方法和一个getValue()方法,因此,上面的代码可以被组织得更符合逻辑。举例如下:

Set entries = map.entrySet( );
		if(entries != null) {
			Iterator iterator = entries.iterator( );
			while(iterator.hasNext( )) {
				Map.Entry entry =iterator.next( );
				Object key = entry.getKey( );
				Object value = entry.getValue();
				;....
			}
		}


尽管增加了一行代码,我们却省略了许多对Map不必要的“get”调用。同时,提供给开发人员一个同时保持了关键字和其对应的值的类。Map.Entry同时也提供了一个setValue()方法,程序员可以使用它修改map里面的值。

Map<String, Integer> map = new TreeMap<String, Integer>();
		map.put("j2se", 20); 
		map.put("j2ee", 10); 
		map.put("j2me", 30);
		List<Map.Entry<String, Integer>> infoIds = new ArrayList<Map.Entry<String, Integer>>(map.entrySet()); 
		//排序前 
		for (int i = 0; i < infoIds.size(); i++) { 
			String id = infoIds.get(i).toString(); 
			System.out.println(id); 
		} 
		//排序 
		Collections.sort(infoIds, new Comparator<Map.Entry<String, Integer>>() { 
			public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) { 
				return (o2.getValue() - o1.getValue()); 
			} 
		}); 
		//排序后 
		for (int i = 0; i < infoIds.size(); i++) { 
			String id = infoIds.get(i).toString(); 
			System.out.println(id); 
		} 
		排序前: 
		j2ee=10 
		j2me=30 
		j2se=20 
		排序后: 
		j2me=30 
		j2se=20 
		j2ee=10 



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值