[java] view plain copy
-
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。
\