如何理解直播APP原始碼開發中的音視訊同步
阿新 • • 發佈:2020-09-18
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());
}
}
}