- 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("======================================================");
- // 只是用sortMap 来引用treeMap实例
- 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
其实上面的排序是用treeMap来实现的,treeMap实现了sortMap 接口
签名生成的通用步骤如下:
第一步,设所有发送或者接收到的数据为集合M,将集合M内非空参数值的参数按照参数名ASCII码从小到大排序(字典序),使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA。