1. 程式人生 > 實用技巧 >如何理解直播APP原始碼開發中的音視訊同步

如何理解直播APP原始碼開發中的音視訊同步

Map集合

  • Collection中的集合,元素是孤立存在的,向集合中儲存元素採用一個個元素的方式儲存。
  • Map中的集合,元素是成對存在的。每個元素由鍵與值兩部分組成,通過鍵可以找對所對應的值。
  • Collection中的集合稱為單列集合,Map中的集合稱為雙列集合。
  • Map中的集合不能包含重複的鍵,值可以重複;每個鍵只能對應一個值。

HashMap<K,V>

  • 儲存資料採用的雜湊表結構,元素的存取順序不能保證一致。由於要保證鍵的唯一、不重複,需要重寫鍵的hashCode()方法、equals()方法。

LinkedHashMap

  • 儲存資料採用的雜湊表結構+連結串列結構。通過連結串列結構可以保證元素的存取順序一致;通過雜湊表結構可以保證的鍵的唯一、不重複,需要重寫鍵的hashCode()方法、equals()方法。
  • Map介面中的集合都有兩個泛型變數<K,V>,在使用時,要為兩個泛型變數賦予資料型別。兩個泛型變數<K,V>的資料型別可以相同,也可以不同。

常用方法

  • public V put(K key, V value): 把指定的鍵與指定的值新增到Map集合中。
  • public V remove(Object key): 把指定的鍵 所對應的鍵值對元素 在Map集合中刪除,返回被刪除元素的值。
  • public V get(Object key) 根據指定的鍵,在Map集合中獲取對應的值。
  • boolean containsKey(Object key) 判斷集合中是否包含指定的鍵。
  • public Set<K> keySet(): 獲取Map集合中所有的鍵,儲存到Set集合中。
  • public Set<Map.Entry<K,V>> entrySet(): 獲取到Map集合中所有的鍵值對物件的集合(Set集合)。

public class MapDemo {
public static void main(String[] args) {
//建立 map物件
HashMap<String, String> map = new HashMap<String, String>();

    //新增元素到集合
    map.put("黃曉明", "楊穎");
    map.put("文章", "馬伊琍");
    map.put("鄧超", "孫儷");
    System.out.println(map);

    //String remove(String key)
    System.out.println(map.remove("鄧超"));
    System.out.println(map);

    // 想要檢視 黃曉明的媳婦 是誰
    System.out.println(map.get("黃曉明"));
    System.out.println(map.get("鄧超"));    
}
}
  • 使用put方法時,若指定的鍵(key)在集合中沒有,則沒有這個鍵對應的值,返回null,並把指定的鍵值新增到集合中;
  • 若指定的鍵(key)在集合中存在,則返回值為集合中鍵對應的值(該值為替換前的值),並把指定鍵所對應的值,替換成指定的新值。

Map集合遍歷鍵找值方式

  • 獲取Map中所有的鍵,由於鍵是唯一的,所以返回一個Set集合儲存所有的鍵。方法提示:keyset()
  • 遍歷鍵的Set集合,得到每一個鍵。
  • 根據鍵,獲取鍵所對應的值。方法提示:get(K key)
public class MapDemo01 {
    public static void main(String[] args) {
        //建立Map集合物件 
        HashMap<String, String> map = new HashMap<String,String>();
        //新增元素到集合 
        map.put("胡歌", "霍建華");
        map.put("郭德綱", "于謙");
        map.put("薛之謙", "大張偉");

        //獲取所有的鍵  獲取鍵集
        Set<String> keys = map.keySet();
        // 遍歷鍵集 得到 每一個鍵
        for (String key : keys) {
          	//key  就是鍵
            //獲取對應值
            String value = map.get(key);
            System.out.println(key+"的CP是:"+value);
        }  
    }
}

Entry鍵值對物件

  • Map中存放的是兩種物件,一種稱為key(鍵),一種稱為value(值),它們在在Map中是一一對應關係,這一對物件又稱做Map中的一個Entry(項)Entry將鍵值對的對應關係封裝成了物件。即鍵值對物件,這樣我們在遍歷Map集合時,就可以從每一個鍵值對(Entry)物件中獲取對應的鍵與對應的值。
  • public K getKey():獲取Entry物件中的鍵。
  • public V getValue():獲取Entry物件中的值。
  • public Set<Map.Entry<K,V>> entrySet(): 獲取到Map集合中所有的鍵值對物件的集合(Set集合)。

Map集合遍歷鍵值對方式

  • 獲取Map集合中,所有的鍵值對(Entry)物件,以Set集合形式返回。方法提示:entrySet()
  • 遍歷包含鍵值對(Entry)物件的Set集合,得到每一個鍵值對(Entry)物件。
  • 通過鍵值對(Entry)物件,獲取Entry物件中的鍵與值。 方法提示:getkey() getValue()
public class MapDemo02 {
    public static void main(String[] args) {
        // 建立Map集合物件 
        HashMap<String, String> map = new HashMap<String,String>();
        // 新增元素到集合 
        map.put("胡歌", "霍建華");
        map.put("郭德綱", "于謙");
        map.put("薛之謙", "大張偉");

        // 獲取 所有的 entry物件  entrySet
        Set<Entry<String,String>> entrySet = map.entrySet();

        // 遍歷得到每一個entry物件
        for (Entry<String, String> entry : entrySet) {
           	// 解析 
            String key = entry.getKey();
            String value = entry.getValue();  
            System.out.println(key+"的CP是:"+value);
        }
    }
}

HashMap儲存自定義型別鍵值

  • 當給HashMap中存放自定義物件時,如果自定義物件作為key存在,這時要保證物件唯一,必須複寫物件的hashCode和equals方法
  • 如果要保證map中存放的key和取出的順序一致

LinkedHashMap

  • 底層是是連結串列和雜湊表組合的一個數據儲存結構。
public class LinkedHashMapDemo {
    public static void main(String[] args) {
        LinkedHashMap<String, String> map = new LinkedHashMap<String, String>();
        map.put("鄧超", "孫儷");
        map.put("李晨", "范冰冰");
        map.put("劉德華", "朱麗倩");
        Set<Entry<String, String>> entrySet = map.entrySet();
        for (Entry<String, String> entry : entrySet) {
            System.out.println(entry.getKey() + "  " + entry.getValue());
        }
    }
}