Map集合的特點
將鍵映射到值的對象,一個映射不能包含重複的鍵,每個鍵只能映射到一個值。
Map集合和Collection集合的區別?
- Map集合存儲元素是成對出現的,Map的鍵是唯一的,值是可重複的。
- Collection集合存儲元素是單獨出現的,Collection的子類Set是唯一,不可重複,List是可重複的。
- Map集合的數據結構只針對鍵有效,和值無關。
- Collection集合的數據結構對元素有效。
常用Api
- 添加功能
V put(K key,V value):
添加元素。這裏的返回值是如果Key鍵不存在,返回值爲null,如果Key鍵存在Map中,就會把上一次Key對應的值返回。 - 刪除功能
void clear():移除所有鍵值對元素。
V remove(Object key):根據鍵刪除鍵值對元素,並把元素返回。 - 判斷功能
boolean containsKey(Object key): 判斷集合是否包含指定的鍵。
boolean containsValue(Object value):判斷集合是否包含指定的值。 - 獲取功能
Set<Map.Entry<K,V>> entrySet:返回鍵值對對象
V get(Object key):根據鍵獲取值,不存在則返回null
Set<K> keySet():獲取集合中所有鍵的集合
Collection<V> values()獲取集合中所有值的集合
(這裏可以看出Map的鍵是由Set接口實現,值由Collection接口實現)
- 長度功能
int size():返回集合中的鍵值對的對數。
例子
/**
*
* @author loveqRc
*
* 需求 :"aababcabcdabcde",獲取字符串中每一個字母出現的次數要求結 果:a(5)b(4)c(3)d(2)e(1)
* 從輸出結果看:第一排序:所以用Tree 。
* 第二元素唯一,也就是abcd..中同一個字母只會出現一次,決定用TreeSet或TreeMap。
* 第三是以鍵值對方式顯示最後決定用TreeMap。
*
*/
public class MapDemo {
public static void main(String[] args) {
TreeMap<Character, Integer> tm = new TreeMap<Character, Integer>();
Scanner scanner=new Scanner(System.in);
System.out.println("請輸入一段字符串:");
String line = scanner.nextLine();
char[] charArray = line.toCharArray();
for (char c : charArray) {
Integer integer = tm.get(c);
if (integer==null) {//如果tm中沒有就返回null
tm.put(c, 1);
}else{
integer++;
tm.put(c, integer);
}
}
StringBuilder sb=new StringBuilder();
Set<Character> keySet = tm.keySet();
for (Character character : keySet) {
Integer integer = tm.get(character);
sb.append(character).append("(").append(integer).append(")");
}
System.out.println("result:"+sb.toString());
//result:a(5)b(4)c(3)d(2)e(1)
}
}