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了,感兴趣的童鞋可以自己去研究!