目录
3.1 Collections:工具类,提供一组静态方法操作Collection集合
Map
1.特点:
无序、以键值对的形式添加元素,键不能重复,值可以重复
它没有继承Collection接口
1.2 遍历
1.2.1 先取出保存所有键的Set,再遍历Set即可(2种)
1.2.2 先取出保存所有Entry的Set,再遍历此Set即可
package com.utils;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
public class Work1 {
public static void main(String[] args) {
/**
* Map 特点:无序 以键值对的形式
*/
Map<String, Object> map = new HashMap<String, Object>();
map.put("name", "asd");
map.put("sex", "男");
map.put("age", 34);
// 键:唯一 (会被覆盖)
map.put("name", "a32sd");
// 值:不唯一(可以重复)
map.put("score", 34);
System.out.println(map);
// 一.定义一个Map集合,key和value不规定类型,任意放入数据,用keySet()和entrySet()两种方式遍历出Map集合的数据
Set<String> keySet = map.keySet();
for (String string : keySet) {
System.out.println(string);
}
System.out.println("----------------------------------------");
Set<Entry<String, Object>> entrySet = map.entrySet();
for (Entry<String, Object> entry : entrySet) {
System.out.println(entry.getKey() + "=" + entry.getValue());
}
// 二.定义一个Map集合,key和value不规定类型,任意放入数据,单独拿到所有的 value的数据
System.out.println("----------------------------------------");
Collection<Object> values = map.values();
for (Object object : values) {
System.out.println(object);
}
}
}
2.HashMap与Hashtable之间的区别(重点)
异步 线程非安全的 hashmap
同步(synchronized)既排队 线程安全的 hashtable
3. 其它
3.1 Collections:工具类,提供一组静态方法操作Collection集合
//collections:集合框架帮助类 进行比较排序
Collections.sort(lst, new Comparator<Entry<String,Student>>() {
@Override
public int compare(Entry<String, Student> o1, Entry<String, Student> o2) {
Student value1 = o1.getValue();
Student value2 = o2.getValue();
return value1.hashCode()-value2.hashCode();
}
});