map根据value排序


import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

public class comparator {
	public static void main(String[] args) {
		Map<String, Double> map = new HashMap<String, Double>();
		map.put("1", 100D);
		map.put("2", 50D);
		map.put("3", 75D);
		map.put("4", 32D);
		map.put("5", 235D);
		map.put("6", 42D);
		map.put("7", 12D);
		map.put("8", 33D);
		map.put("9", 221D);

		List<Map.Entry<String, Double>> list = new ArrayList<Map.Entry<String, Double>>(map.entrySet());
		Collections.sort(list, new Comparator<Map.Entry<String, Double>>() {
			// 降序排序
			public int compare(Entry<String, Double> o1, Entry<String, Double> o2) {
				return -o1.getValue().compareTo(o2.getValue());
			}
		});

		for (Map.Entry<String, Double> mapping : list) {
			System.out.println(mapping.getKey() + ":" + mapping.getValue());
		}
	}
}
修改为 return o1.getValue().compareTo(o2.getValue());便可进行升序排序。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM