Java學習筆記--Map接口

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)
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章