SortedMap的用法

package Map;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Set;
import java.util.SortedMap;
import java.util.TreeMap;
import java.util.Map.Entry;

/**
 * HashMap比SortedMap快,非排序的时候用HashMap
 * @author Administrator
 *
 */
public class Sortedmap {
	public static void main(String[] args) {
		HashMap<String,String> map=new HashMap<String, String>();
		map.put("1","11");
		map.put("2", "22");
		map.put("3", "33");
		for (Entry<String,String> entry: map.entrySet()) {
			System.out.println("排序之前:"+entry.getKey()+" 值"+entry.getValue());

		}
		System.out.println("======================================================");
		SortedMap<String,String> sort=new TreeMap<String,String>(map);
		Set<Entry<String,String>> entry1=sort.entrySet();
		Iterator<Entry<String,String>> it=entry1.iterator();
		while(it.hasNext())
		{
			Entry<String,String> entry=it.next();
			System.out.println("排序之后:"+entry.getKey()+" 值"+entry.getValue());
		}
	}



}


排序之前:3 值33
排序之前:2 值22
排序之前:1 值11
======================================================
排序之后:1 值11
排序之后:2 值22
排序之后:3 值33

说明:HashMap比SortedMap快,非排序的时候用HashMap


具体使用到的地方:微信支付生成签名sign的时候,api的原文是

签名生成的通用步骤如下:

第一步,设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA。


网上你根据SortedMap来搜索的时候,一般都是跟TreeMap的区别,看见一大段的文字就头晕,这里就不提供了URL了,感兴趣的童鞋可以自己去研究!

你可能感兴趣的:(SortedMap)