日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java list有序还是无序_牛批!2w字的Java集合框架面试题精华集(2020最新版),赶紧收藏。...

發布時間:2025/4/5 java 61 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java list有序还是无序_牛批!2w字的Java集合框架面试题精华集(2020最新版),赶紧收藏。... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一個多月前,作者和一些小伙伴決定做一系列的 Java 知識點常見重要問題的小冊,方便用來夯實基礎!小冊的標準就一個,那就是:取精華,取重點。每一本小冊,我們都會充分關注我們所總結的知識點是否達到這個標準。

昨天晚上終于把 Java 集合框架部分的的知識點肝完了,轉換成 PDF 一共 25 頁,轉發+關注,然后【點擊下方鏈接】即可獲得PDF版的免費領取方式。(提供夜間閱讀版)

點擊免費領取Java架構資料?shimo.im

很多小伙伴可能會問這個和《JavaGuide面試突擊》不是不沖突了么?我都看了 《JavaGuide面試突擊》,為啥還有這個,還嫌我頭發不夠少么,草,作者你可真壞!

實際上,兩者是不沖突的。 首先,兩者的內容在很大程度上都是一樣的。但是,《Java 知識點常見重要問題的小冊》的話知識點會稍微更加全面一點,更加適合自己系統復習知識,而《JavaGuide面試突擊》更加適合準備面試。

集合概述

Java 集合概覽

從下圖可以看出,在 Java 中除了以 Map 結尾的類之外, 其他類都實現了 Collection 接口。

并且,以 Map 結尾的類都實現了 Map 接口。

說說 List,Set,Map 三者的區別?

  • List(對付順序的好幫手):存儲的元素是有序的、可重復的。
  • Set(注重獨一無二的性質): 存儲的元素是無序的、不可重復的。
  • Map(用 Key 來搜索的專家): 使用鍵值對(kye-value)存儲,類似于數學上的函數 y=f(x),“x”代表 key,"y"代表 value,Key 是無序的、不可重復的,value 是無序的、可重復的,每個鍵最多映射到一個值。

集合框架底層數據結構總結

先來看一下 Collection 接口下面的集合。

List

  • Arraylist:Object[]數組
  • Vector:Object[]數組
  • LinkedList:雙向鏈表(JDK1.6 之前為循環鏈表,JDK1.7 取消了循環)

Set

  • HashSet(無序,唯一): 基于 HashMap 實現的,底層采用 HashMap 來保存元素
  • LinkedHashSet:LinkedHashSet 是 HashSet 的子類,并且其內部是通過 LinkedHashMap 來實現的。有點類似于我們之前說的 LinkedHashMap 其內部是基于 HashMap 實現一樣,不過還是有一點點區別的
  • TreeSet(有序,唯一):紅黑樹(自平衡的排序二叉樹)

再來看看 Map 接口下面的集合。

Map

  • HashMap:JDK1.8 之前 HashMap 由數組+鏈表組成的,數組是 HashMap 的主體,鏈表則是主要為了解決哈希沖突而存在的(“拉鏈法”解決沖突)。JDK1.8 以后在解決哈希沖突時有了較大的變化,當鏈表長度大于閾值(默認為 8)(將鏈表轉換成紅黑樹前會判斷,如果當前數組的長度小于 64,那么會選擇先進行數組擴容,而不是轉換為紅黑樹)時,將鏈表轉化為紅黑樹,以減少搜索時間
  • LinkedHashMap:LinkedHashMap 繼承自 HashMap,所以它的底層仍然是基于拉鏈式散列結構即由數組和鏈表或紅黑樹組成。另外,LinkedHashMap 在上面結構的基礎上,增加了一條雙向鏈表,使得上面的結構可以保持鍵值對的插入順序。同時通過對鏈表進行相應的操作,實現了訪問順序相關邏輯。詳細可以查看:《LinkedHashMap 源碼詳細分析(JDK1.8)》
  • Hashtable:數組+鏈表組成的,數組是 HashMap 的主體,鏈表則是主要為了解決哈希沖突而存在的
  • TreeMap:紅黑樹(自平衡的排序二叉樹)

如何選用集合?

主要根據集合的特點來選用,比如我們需要根據鍵值獲取到元素值時就選用 Map 接口下的集合,需要排序時選擇 TreeMap,不需要排序時就選擇 HashMap,需要保證線程安全就選用 ConcurrentHashMap。

當我們只需要存放元素值時,就選擇實現Collection 接口的集合,需要保證元素唯一時選擇實現 Set 接口的集合比如 TreeSet 或 HashSet,不需要就選擇實現 List 接口的比如 ArrayList 或 LinkedList,然后再根據實現這些接口的集合的特點來選用。

為什么要使用集合?

當我們需要保存一組類型相同的數據的時候,我們應該是用一個容器來保存,這個容器就是數組,但是,使用數組存儲對象具有一定的弊端, 因為我們在實際開發中,存儲的數據的類型是多種多樣的,于是,就出現了“集合”,集合同樣也是用來存儲多個數據的。

數組的缺點是一旦聲明之后,長度就不可變了;同時,聲明數組時的數據類型也決定了該數組存儲的數據的類型;而且,數組存儲的數據是有序的、可重復的,特點單一。但是集合提高了數據存儲的靈活性,Java 集合不僅可以用來存儲不同類型不同數量的對象,還可以保存具有映射關系的數據

Iterator 迭代器

迭代器 Iterator 是什么?

public interface Iterator<E> {//集合中是否還有元素boolean hasNext();//獲得集合中的下一個元素E next();...... }

Iterator 對象稱為迭代器(設計模式的一種),迭代器可以對集合進行遍歷,但每一個集合內部的數據結構可能是不盡相同的,所以每一個集合存和取都很可能是不一樣的,雖然我們可以人為地在每一個類中定義 hasNext() 和 next() 方法,但這樣做會讓整個集合體系過于臃腫。于是就有了迭代器。

迭代器是將這樣的方法抽取出接口,然后在每個類的內部,定義自己迭代方式,這樣做就規定了整個集合體系的遍歷方式都是 hasNext()和next()方法,使用者不用管怎么實現的,會用即可。迭代器的定義為:提供一種方法訪問一個容器對象中各個元素,而又不需要暴露該對象的內部細節。

迭代器 Iterator 有啥用?

Iterator 主要是用來遍歷集合用的,它的特點是更加安全,因為它可以確保,在當前遍歷的集合元素被更改的時候,就會拋出 ConcurrentModificationException 異常。

如何使用?

我們通過使用迭代器來遍歷 HashMap,演示一下 迭代器 Iterator 的使用。

Map<Integer, String> map = new HashMap(); map.put(1, "Java"); map.put(2, "C++"); map.put(3, "PHP"); Iterator<Map.Entry<Integer, String>> iterator = map.entrySet().iterator(); while (iterator.hasNext()) {Map.Entry<Integer, String> entry = iterator.next();System.out.println(entry.getKey() + entry.getValue()); }

有哪些集合是線程不安全的?怎么解決呢?

我們常用的 Arraylist ,LinkedList,Hashmap,HashSet,TreeSet,TreeMap,PriorityQueue 都不是線程安全的。解決辦法很簡單,可以使用線程安全的集合來代替。

如果你要使用線程安全的集合的話, java.util.concurrent 包中提供了很多并發容器供你使用:

  • ConcurrentHashMap: 可以看作是線程安全的 HashMap
  • CopyOnWriteArrayList:可以看作是線程安全的 ArrayList,在讀多寫少的場合性能非常好,遠遠好于 Vector.
  • ConcurrentLinkedQueue:高效的并發隊列,使用鏈表實現。可以看做一個線程安全的 LinkedList,這是一個非阻塞隊列。
  • BlockingQueue: 這是一個接口,JDK 內部通過鏈表、數組等方式實現了這個接口。表示阻塞隊列,非常適合用于作為數據共享的通道。
  • ConcurrentSkipListMap :跳表的實現。這是一個Map,使用跳表的數據結構進行快速查找。
  • Collection 子接口之 List

    Arraylist 和 Vector 的區別?

  • ArrayList 是 List 的主要實現類,底層使用 Object[ ]存儲,適用于頻繁的查找工作,線程不安全 ;
  • Vector 是 List 的古老實現類,底層使用 Object[ ]存儲,線程安全的。
  • Arraylist 與 LinkedList 區別?

  • 是否保證線程安全: ArrayList 和 LinkedList 都是不同步的,也就是不保證線程安全;
  • 底層數據結構: Arraylist 底層使用的是 Object 數組;LinkedList 底層使用的是 雙向鏈表 數據結構(JDK1.6 之前為循環鏈表,JDK1.7 取消了循環。注意雙向鏈表和雙向循環鏈表的區別,下面有介紹到!)
  • 插入和刪除是否受元素位置的影響: ① ArrayList 采用數組存儲,所以插入和刪除元素的時間復雜度受元素位置的影響。 比如:執行add(E e)方法的時候, ArrayList 會默認在將指定的元素追加到此列表的末尾,這種情況時間復雜度就是 O(1)。但是如果要在指定位置 i 插入和刪除元素的話(add(int index, E element))時間復雜度就為 O(n-i)。因為在進行上述操作的時候集合中第 i 和第 i 個元素之后的(n-i)個元素都要執行向后位/向前移一位的操作。② LinkedList 采用鏈表存儲,所以對于add(E e)方法的插入,刪除元素時間復雜度不受元素位置的影響,近似 O(1),如果是要在指定位置i插入和刪除元素的話((add(int index, E element)) 時間復雜度近似為o(n))因為需要先移動到指定位置再插入。
  • 是否支持快速隨機訪問: LinkedList 不支持高效的隨機元素訪問,而 ArrayList 支持。快速隨機訪問就是通過元素的序號快速獲取元素對象(對應于get(int index)方法)。
  • 內存空間占用: ArrayList 的空 間浪費主要體現在在 list 列表的結尾會預留一定的容量空間,而 LinkedList 的空間花費則體現在它的每一個元素都需要消耗比 ArrayList 更多的空間(因為要存放直接后繼和直接前驅以及數據)。
  • 補充內容:雙向鏈表和雙向循環鏈表

    雙向鏈表: 包含兩個指針,一個 prev 指向前一個節點,一個 next 指向后一個節點。

    雙向循環鏈表: 最后一個節點的 next 指向 head,而 head 的 prev 指向最后一個節點,構成一個環。

    補充內容:RandomAccess 接口

    public interface RandomAccess { }

    查看源碼我們發現實際上 RandomAccess 接口中什么都沒有定義。所以,在我看來 RandomAccess 接口不過是一個標識罷了。標識什么?標識實現這個接口的類具有隨機訪問功能。

    在 binarySearch() 方法中,它要判斷傳入的 list 是否 RamdomAccess 的實例,如果是,調用indexedBinarySearch()方法,如果不是,那么調用iteratorBinarySearch()方法

    public static <T>int binarySearch(List<? extends Comparable<? super T>> list, T key) {if (list instanceof RandomAccess || list.size()<BINARYSEARCH_THRESHOLD)return Collections.indexedBinarySearch(list, key);elsereturn Collections.iteratorBinarySearch(list, key);}

    ArrayList 實現了 RandomAccess 接口, 而 LinkedList 沒有實現。為什么呢?我覺得還是和底層數據結構有關!ArrayList 底層是數組,而 LinkedList 底層是鏈表。數組天然支持隨機訪問,時間復雜度為 O(1),所以稱為快速隨機訪問。鏈表需要遍歷到特定位置才能訪問特定位置的元素,時間復雜度為 O(n),所以不支持快速隨機訪問。,ArrayList 實現了 RandomAccess 接口,就表明了它具有快速隨機訪問功能。RandomAccess 接口只是標識,并不是說 ArrayList 實現 RandomAccess 接口才具有快速隨機訪問功能的!

    說一說 ArrayList 的擴容機制吧

    詳見筆者的這篇文章:通過源碼一步一步分析 ArrayList 擴容機制

    Collection 子接口之 Set

    comparable 和 Comparator 的區別

    • comparable 接口實際上是出自java.lang包 它有一個 compareTo(Object obj)方法用來排序
    • comparator接口實際上是出自 java.util 包它有一個compare(Object obj1, Object obj2)方法用來排序

    一般我們需要對一個集合使用自定義排序時,我們就要重寫compareTo()方法或compare()方法,當我們需要對某一個集合實現兩種排序方式,比如一個 song 對象中的歌名和歌手名分別采用一種排序方法的話,我們可以重寫compareTo()方法和使用自制的Comparator方法或者以兩個 Comparator 來實現歌名排序和歌星名排序,第二種代表我們只能使用兩個參數版的 Collections.sort().

    Comparator 定制排序

    ArrayList<Integer> arrayList = new ArrayList<Integer>();arrayList.add(-1);arrayList.add(3);arrayList.add(3);arrayList.add(-5);arrayList.add(7);arrayList.add(4);arrayList.add(-9);arrayList.add(-7);System.out.println("原始數組:");System.out.println(arrayList);// void reverse(List list):反轉Collections.reverse(arrayList);System.out.println("Collections.reverse(arrayList):");System.out.println(arrayList);// void sort(List list),按自然排序的升序排序Collections.sort(arrayList);System.out.println("Collections.sort(arrayList):");System.out.println(arrayList);// 定制排序的用法Collections.sort(arrayList, new Comparator<Integer>() {@Overridepublic int compare(Integer o1, Integer o2) {return o2.compareTo(o1);}});System.out.println("定制排序后:");System.out.println(arrayList);

    Output:

    原始數組: [-1, 3, 3, -5, 7, 4, -9, -7] Collections.reverse(arrayList): [-7, -9, 4, 7, -5, 3, 3, -1] Collections.sort(arrayList): [-9, -7, -5, -1, 3, 3, 4, 7] 定制排序后: [7, 4, 3, 3, -1, -5, -7, -9]

    重寫 compareTo 方法實現按年齡來排序

    // person對象沒有實現Comparable接口,所以必須實現,這樣才不會出錯,才可以使treemap中的數據按順序排列 // 前面一個例子的String類已經默認實現了Comparable接口,詳細可以查看String類的API文檔,另外其他 // 像Integer類等都已經實現了Comparable接口,所以不需要另外實現了 public class Person implements Comparable<Person> {private String name;private int age;public Person(String name, int age) {super();this.name = name;this.age = age;}public String getName() {return name;}public void setName(String name) {this.name = name;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}/*** T重寫compareTo方法實現按年齡來排序*/@Overridepublic int compareTo(Person o) {if (this.age > o.getAge()) {return 1;}if (this.age < o.getAge()) {return -1;}return 0;} }public static void main(String[] args) {TreeMap<Person, String> pdata = new TreeMap<Person, String>();pdata.put(new Person("張三", 30), "zhangsan");pdata.put(new Person("李四", 20), "lisi");pdata.put(new Person("王五", 10), "wangwu");pdata.put(new Person("小紅", 5), "xiaohong");// 得到key的值的同時得到key所對應的值Set<Person> keys = pdata.keySet();for (Person key : keys) {System.out.println(key.getAge() + "-" + key.getName());}}

    Output:

    5-小紅 10-王五 20-李四 30-張三

    無序性和不可重復性的含義是什么

    1、什么是無序性?無序性不等于隨機性 ,無序性是指存儲的數據在底層數組中并非按照數組索引的順序添加 ,而是根據數據的哈希值決定的。

    2、什么是不可重復性?不可重復性是指添加的元素按照 equals()判斷時 ,返回 false,需要同時重寫 equals()方法和 HashCode()方法。

    比較 HashSet、LinkedHashSet 和 TreeSet 三者的異同

    HashSet 是 Set 接口的主要實現類 ,HashSet 的底層是 HashMap,線程不安全的,可以存儲 null 值;

    LinkedHashSet 是 HashSet 的子類,能夠按照添加的順序遍歷;

    TreeSet 底層使用紅黑樹,能夠按照添加元素的順序進行遍歷,排序的方式有自然排序和定制排序。

    Map 接口

    HashMap 和 Hashtable 的區別

  • 線程是否安全: HashMap 是非線程安全的,HashTable 是線程安全的,因為 HashTable 內部的方法基本都經過synchronized 修飾。(如果你要保證線程安全的話就使用 ConcurrentHashMap 吧!);
  • 效率: 因為線程安全的問題,HashMap 要比 HashTable 效率高一點。另外,HashTable 基本被淘汰,不要在代碼中使用它;
  • 對 Null key 和 Null value 的支持: HashMap 可以存儲 null 的 key 和 value,但 null 作為鍵只能有一個,null 作為值可以有多個;HashTable 不允許有 null 鍵和 null 值,否則會拋出 NullPointerException。
  • 初始容量大小和每次擴充容量大小的不同 : ① 創建時如果不指定容量初始值,Hashtable 默認的初始大小為 11,之后每次擴充,容量變為原來的 2n+1。HashMap 默認的初始化大小為 16。之后每次擴充,容量變為原來的 2 倍。② 創建時如果給定了容量初始值,那么 Hashtable 會直接使用你給定的大小,而 HashMap 會將其擴充為 2 的冪次方大小(HashMap 中的tableSizeFor()方法保證,下面給出了源代碼)。也就是說 HashMap 總是使用 2 的冪作為哈希表的大小,后面會介紹到為什么是 2 的冪次方。
  • 底層數據結構: JDK1.8 以后的 HashMap 在解決哈希沖突時有了較大的變化,當鏈表長度大于閾值(默認為 8)(將鏈表轉換成紅黑樹前會判斷,如果當前數組的長度小于 64,那么會選擇先進行數組擴容,而不是轉換為紅黑樹)時,將鏈表轉化為紅黑樹,以減少搜索時間。Hashtable 沒有這樣的機制。
  • HashMap 中帶有初始容量的構造函數:

    public HashMap(int initialCapacity, float loadFactor) {if (initialCapacity < 0)throw new IllegalArgumentException("Illegal initial capacity: " +initialCapacity);if (initialCapacity > MAXIMUM_CAPACITY)initialCapacity = MAXIMUM_CAPACITY;if (loadFactor <= 0 || Float.isNaN(loadFactor))throw new IllegalArgumentException("Illegal load factor: " +loadFactor);this.loadFactor = loadFactor;this.threshold = tableSizeFor(initialCapacity);}public HashMap(int initialCapacity) {this(initialCapacity, DEFAULT_LOAD_FACTOR);}

    下面這個方法保證了 HashMap 總是使用 2 的冪作為哈希表的大小。

    /*** Returns a power of two size for the given target capacity.*/static final int tableSizeFor(int cap) {int n = cap - 1;n |= n >>> 1;n |= n >>> 2;n |= n >>> 4;n |= n >>> 8;n |= n >>> 16;return (n < 0) ? 1 : (n >= MAXIMUM_CAPACITY) ? MAXIMUM_CAPACITY : n + 1;}

    HashMap 和 HashSet 區別

    如果你看過 HashSet 源碼的話就應該知道:HashSet 底層就是基于 HashMap 實現的。(HashSet 的源碼非常非常少,因為除了 clone()、writeObject()、readObject()是 HashSet 自己不得不實現之外,其他方法都是直接調用 HashMap 中的方法。

    HashMap 和 TreeMap 區別

    TreeMap 和HashMap 都繼承自AbstractMap ,但是需要注意的是TreeMap它還實現了NavigableMap接口和SortedMap 接口。

    實現 NavigableMap 接口讓 TreeMap 有了對集合內元素的搜索的能力。

    實現SortMap接口讓 TreeMap 有了對集合中的元素根據鍵排序的能力。默認是按 key 的升序排序,不過我們也可以指定排序的比較器。示例代碼如下:

    /*** @author shuang.kou* @createTime 2020年06月15日 17:02:00*/ public class Person {private Integer age;public Person(Integer age) {this.age = age;}public Integer getAge() {return age;}public static void main(String[] args) {TreeMap<Person, String> treeMap = new TreeMap<>(new Comparator<Person>() {@Overridepublic int compare(Person person1, Person person2) {int num = person1.getAge() - person2.getAge();return Integer.compare(num, 0);}});treeMap.put(new Person(3), "person1");treeMap.put(new Person(18), "person2");treeMap.put(new Person(35), "person3");treeMap.put(new Person(16), "person4");treeMap.entrySet().stream().forEach(personStringEntry -> {System.out.println(personStringEntry.getValue());});} }

    輸出:

    person1 person4 person2 person3

    可以看出,TreeMap 中的元素已經是按照 Person 的 age 字段的升序來排列了。

    上面,我們是通過傳入匿名內部類的方式實現的,你可以將代碼替換成 Lambda 表達式實現的方式:

    TreeMap<Person, String> treeMap = new TreeMap<>((person1, person2) -> {int num = person1.getAge() - person2.getAge();return Integer.compare(num, 0); });

    綜上,相比于HashMap來說 TreeMap 主要多了對集合中的元素根據鍵排序的能力以及對集合內元素的搜索的能力。

    HashSet 如何檢查重復

    當你把對象加入HashSet時,HashSet 會先計算對象的hashcode值來判斷對象加入的位置,同時也會與其他加入的對象的 hashcode 值作比較,如果沒有相符的 hashcode,HashSet 會假設對象沒有重復出現。但是如果發現有相同 hashcode 值的對象,這時會調用equals()方法來檢查 hashcode 相等的對象是否真的相同。如果兩者相同,HashSet 就不會讓加入操作成功。(摘自我的 Java 啟蒙書《Head fist java》第二版)

    hashCode()與 equals()的相關規定:

  • 如果兩個對象相等,則 hashcode 一定也是相同的
  • 兩個對象相等,對兩個 equals 方法返回 true
  • 兩個對象有相同的 hashcode 值,它們也不一定是相等的
  • 綜上,equals 方法被覆蓋過,則 hashCode 方法也必須被覆蓋
  • hashCode()的默認行為是對堆上的對象產生獨特值。如果沒有重寫 hashCode(),則該 class 的兩個對象無論如何都不會相等(即使這兩個對象指向相同的數據)。
  • ==與 equals 的區別

    對于基本類型來說,== 比較的是值是否相等;

    對于引用類型來說,== 比較的是兩個引用是否指向同一個對象地址(兩者在內存中存放的地址(堆內存地址)是否指向同一個地方);

    對于引用類型(包括包裝類型)來說,equals 如果沒有被重寫,對比它們的地址是否相等;如果 equals()方法被重寫(例如 String),則比較的是地址里的內容。

    HashMap 的底層實現

    JDK1.8 之前

    JDK1.8 之前 HashMap 底層是 數組和鏈表 結合在一起使用也就是 鏈表散列。HashMap 通過 key 的 hashCode 經過擾動函數處理過后得到 hash 值,然后通過 (n - 1) & hash 判斷當前元素存放的位置(這里的 n 指的是數組的長度),如果當前位置存在元素的話,就判斷該元素與要存入的元素的 hash 值以及 key 是否相同,如果相同的話,直接覆蓋,不相同就通過拉鏈法解決沖突。

    所謂擾動函數指的就是 HashMap 的 hash 方法。使用 hash 方法也就是擾動函數是為了防止一些實現比較差的 hashCode() 方法 換句話說使用擾動函數之后可以減少碰撞。

    JDK 1.8 HashMap 的 hash 方法源碼:

    JDK 1.8 的 hash 方法 相比于 JDK 1.7 hash 方法更加簡化,但是原理不變。

    static final int hash(Object key) {int h;// key.hashCode():返回散列值也就是hashcode// ^ :按位異或// >>>:無符號右移,忽略符號位,空位都以0補齊return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);}

    對比一下 JDK1.7 的 HashMap 的 hash 方法源碼.

    static int hash(int h) {// This function ensures that hashCodes that differ only by// constant multiples at each bit position have a bounded// number of collisions (approximately 8 at default load factor).h ^= (h >>> 20) ^ (h >>> 12);return h ^ (h >>> 7) ^ (h >>> 4); }

    相比于 JDK1.8 的 hash 方法 ,JDK 1.7 的 hash 方法的性能會稍差一點點,因為畢竟擾動了 4 次。

    所謂 “拉鏈法” 就是:將鏈表和數組相結合。也就是說創建一個鏈表數組,數組中每一個就是一個鏈表。若遇到哈希沖突,則將沖突的值加到鏈表中即可。

    jdk1.8之前的內部結構-HashMap

    JDK1.8 之后

    相比于之前的版本, JDK1.8 之后在解決哈希沖突時有了較大的變化,當鏈表長度大于閾值(默認為 8)(將鏈表轉換成紅黑樹前會判斷,如果當前數組的長度小于 64,那么會選擇先進行數組擴容,而不是轉換為紅黑樹)時,將鏈表轉化為紅黑樹,以減少搜索時間。

    jdk1.8之后的內部結構-HashMap


    TreeMap、TreeSet 以及 JDK1.8 之后的 HashMap 底層都用到了紅黑樹。紅黑樹就是為了解決二叉查找樹的缺陷,因為二叉查找樹在某些情況下會退化成一個線性結構。

    HashMap 的長度為什么是 2 的冪次方

    為了能讓 HashMap 存取高效,盡量較少碰撞,也就是要盡量把數據分配均勻。我們上面也講到了過了,Hash 值的范圍值-2147483648 到 2147483647,前后加起來大概 40 億的映射空間,只要哈希函數映射得比較均勻松散,一般應用是很難出現碰撞的。但問題是一個 40 億長度的數組,內存是放不下的。所以這個散列值是不能直接拿來用的。用之前還要先做對數組的長度取模運算,得到的余數才能用來要存放的位置也就是對應的數組下標。這個數組下標的計算方法是“ (n - 1) & hash”。(n 代表數組長度)。這也就解釋了 HashMap 的長度為什么是 2 的冪次方。

    這個算法應該如何設計呢?

    我們首先可能會想到采用%區余的操作來實現。但是,重點來了:“取余(%)操作中如果除數是 2 的冪次則等價于與其除數減一的與(&)操作(也就是說 hash%length==hash&(length-1)的前提是 length 是 2 的 n 次方;)。” 并且 采用二進制位操作 &,相對于%能夠提高運算效率,這就解釋了 HashMap 的長度為什么是 2 的冪次方。

    HashMap 多線程操作導致死循環問題

    主要原因在于并發下的 Rehash 會造成元素之間會形成一個循環鏈表。不過,jdk 1.8 后解決了這個問題,但是還是不建議在多線程下使用 HashMap,因為多線程下使用 HashMap 還是會存在其他問題比如數據丟失。并發環境下推薦使用 ConcurrentHashMap 。

    詳情請查看:https://coolshell.cn/articles/9606.html

    HashMap 有哪幾種常見的遍歷方式?

    HashMap 的 7 種遍歷方式與性能分析!

    ConcurrentHashMap 和 Hashtable 的區別

    ConcurrentHashMap 和 Hashtable 的區別主要體現在實現線程安全的方式上不同。

    • 底層數據結構: JDK1.7 的 ConcurrentHashMap 底層采用 分段的數組+鏈表 實現,JDK1.8 采用的數據結構跟 HashMap1.8 的結構一樣,數組+鏈表/紅黑二叉樹。Hashtable 和 JDK1.8 之前的 HashMap 的底層數據結構類似都是采用 數組+鏈表 的形式,數組是 HashMap 的主體,鏈表則是主要為了解決哈希沖突而存在的;
    • 實現線程安全的方式(重要): ① 在 JDK1.7 的時候,ConcurrentHashMap(分段鎖) 對整個桶數組進行了分割分段(Segment),每一把鎖只鎖容器其中一部分數據,多線程訪問容器里不同數據段的數據,就不會存在鎖競爭,提高并發訪問率。到了 JDK1.8 的時候已經摒棄了 Segment 的概念,而是直接用 Node 數組+鏈表+紅黑樹的數據結構來實現,并發控制使用 synchronized 和 CAS 來操作。(JDK1.6 以后 對 synchronized 鎖做了很多優化) 整個看起來就像是優化過且線程安全的 HashMap,雖然在 JDK1.8 中還能看到 Segment 的數據結構,但是已經簡化了屬性,只是為了兼容舊版本;② Hashtable(同一把鎖) :使用 synchronized 來保證線程安全,效率非常低下。當一個線程訪問同步方法時,其他線程也訪問同步方法,可能會進入阻塞或輪詢狀態,如使用 put 添加元素,另一個線程不能使用 put 添加元素,也不能使用 get,競爭會越來越激烈效率越低。

    兩者的對比圖:

    HashTable:

    JDK1.7 的 ConcurrentHashMap:

    JDK1.7的ConcurrentHashMap

    JDK1.8 的 ConcurrentHashMap:

    JDK1.8 的 ConcurrentHashMap

    JDK1.8 的 ConcurrentHashMap 不再是 Segment 數組 + HashEntry 數組 + 鏈表,而是 Node 數組 + 鏈表 / 紅黑樹。不過,Node 只能用于鏈表的情況,紅黑樹的情況需要使用 TreeNode。當沖突鏈表達到一定長度時,鏈表會轉換成紅黑樹。

    ConcurrentHashMap 線程安全的具體實現方式/底層具體實現

    JDK1.7(上面有示意圖)

    首先將數據分為一段一段的存儲,然后給每一段數據配一把鎖,當一個線程占用鎖訪問其中一個段數據時,其他段的數據也能被其他線程訪問。

    ConcurrentHashMap 是由 Segment 數組結構和 HashEntry 數組結構組成。

    Segment 實現了 ReentrantLock,所以 Segment 是一種可重入鎖,扮演鎖的角色。HashEntry 用于存儲鍵值對數據。

    static class Segment<K,V> extends ReentrantLock implements Serializable { }

    一個 ConcurrentHashMap 里包含一個 Segment 數組。Segment 的結構和 HashMap 類似,是一種數組和鏈表結構,一個 Segment 包含一個 HashEntry 數組,每個 HashEntry 是一個鏈表結構的元素,每個 Segment 守護著一個 HashEntry 數組里的元素,當對 HashEntry 數組的數據進行修改時,必須首先獲得對應的 Segment 的鎖。

    JDK1.8 (上面有示意圖)

    ConcurrentHashMap 取消了 Segment 分段鎖,采用 CAS 和 synchronized 來保證并發安全。數據結構跟 HashMap1.8 的結構類似,數組+鏈表/紅黑二叉樹。Java 8 在鏈表長度超過一定閾值(8)時將鏈表(尋址時間復雜度為 O(N))轉換為紅黑樹(尋址時間復雜度為 O(log(N)))

    synchronized 只鎖定當前鏈表或紅黑二叉樹的首節點,這樣只要 hash 不沖突,就不會產生并發,效率又提升 N 倍。

    Collections 工具類

    Collections 工具類常用方法:

  • 排序
  • 查找,替換操作
  • 同步控制(不推薦,需要線程安全的集合類型時請考慮使用 JUC 包下的并發集合)
  • 排序操作

    void reverse(List list)//反轉 void shuffle(List list)//隨機排序 void sort(List list)//按自然排序的升序排序 void sort(List list, Comparator c)//定制排序,由Comparator控制排序邏輯 void swap(List list, int i , int j)//交換兩個索引位置的元素 void rotate(List list, int distance)//旋轉。當distance為正數時,將list后distance個元素整體移到前面。當distance為負數時,將 list的前distance個元素整體移到后面

    查找,替換操作

    int binarySearch(List list, Object key)//對List進行二分查找,返回索引,注意List必須是有序的 int max(Collection coll)//根據元素的自然順序,返回最大的元素。 類比int min(Collection coll) int max(Collection coll, Comparator c)//根據定制排序,返回最大元素,排序規則由Comparatator類控制。類比int min(Collection coll, Comparator c) void fill(List list, Object obj)//用指定的元素代替指定list中的所有元素。 int frequency(Collection c, Object o)//統計元素出現次數 int indexOfSubList(List list, List target)//統計target在list中第一次出現的索引,找不到則返回-1,類比int lastIndexOfSubList(List source, list target). boolean replaceAll(List list, Object oldVal, Object newVal), 用新元素替換舊元素

    同步控制

    Collections 提供了多個synchronizedXxx()方法·,該方法可以將指定集合包裝成線程同步的集合,從而解決多線程并發訪問集合時的線程安全問題。

    我們知道 HashSet,TreeSet,ArrayList,LinkedList,HashMap,TreeMap 都是線程不安全的。Collections 提供了多個靜態方法可以把它們包裝成線程同步的集合。

    最好不要用下面這些方法,效率非常低,需要線程安全的集合類型時請考慮使用 JUC 包下的并發集合。

    方法如下:

    synchronizedCollection(Collection<T> c) //返回指定 collection 支持的同步(線程安全的)collection。 synchronizedList(List<T> list)//返回指定列表支持的同步(線程安全的)List。 synchronizedMap(Map<K,V> m) //返回由指定映射支持的同步(線程安全的)Map。 synchronizedSet(Set<T> s) //返回指定 set 支持的同步(線程安全的)set。

    其他重要問題

    什么是快速失敗(fail-fast)?

    快速失敗(fail-fast) 是 Java 集合的一種錯誤檢測機制。在使用迭代器對集合進行遍歷的時候,我們在多線程下操作非安全失敗(fail-safe)的集合類可能就會觸發 fail-fast 機制,導致拋出 ConcurrentModificationException 異常。另外,在單線程下,如果在遍歷過程中對集合對象的內容進行了修改的話也會觸發 fail-fast 機制。


    注:增強 for 循環也是借助迭代器進行遍歷。

    舉個例子:多線程下,如果線程 1 正在對集合進行遍歷,此時線程 2 對集合進行修改(增加、刪除、修改),或者線程 1 在遍歷過程中對集合進行修改,都會導致線程 1 拋出 ConcurrentModificationException 異常。

    為什么呢?

    每當迭代器使用 hashNext()/next()遍歷下一個元素之前,都會檢測 modCount 變量是否為 expectedModCount 值,是的話就返回遍歷;否則拋出異常,終止遍歷。

    如果我們在集合被遍歷期間對其進行修改的話,就會改變 modCount 的值,進而導致 modCount != expectedModCount ,進而拋出 ConcurrentModificationException 異常。


    注:通過 Iterator 的方法修改集合的話會修改到 expectedModCount 的值,所以不會拋出異常。final void checkForComodification() {if (modCount != expectedModCount)throw new ConcurrentModificationException(); }

    好吧!相信大家已經搞懂了快速失敗(fail-fast)機制以及它的原理。

    我們再來趁熱打鐵,看一個阿里巴巴手冊相關的規定:

    有了前面講的基礎,我們應該知道:使用 Iterator 提供的 remove 方法,可以修改到 expectedModCount 的值。所以,才不會再拋出ConcurrentModificationException 異常。

    什么是安全失敗(fail-safe)呢?

    明白了快速失敗(fail-fast)之后,安全失敗(fail-safe)我們就很好理解了。

    采用安全失敗機制的集合容器,在遍歷時不是直接在集合內容上訪問的,而是先復制原有集合內容,在拷貝的集合上進行遍歷。所以,在遍歷過程中對原集合所作的修改并不能被迭代器檢測到,故不會拋 ConcurrentModificationException 異常。

    Arrays.asList()避坑指南

    最近使用Arrays.asList()遇到了一些坑,然后在網上看到這篇文章:Java Array to List Examples 感覺挺不錯的,但是還不是特別全面。所以,自己對于這塊小知識點進行了簡單的總結。

    簡介

    Arrays.asList()在平時開發中還是比較常見的,我們可以使用它將一個數組轉換為一個 List 集合。

    String[] myArray = { "Apple", "Banana", "Orange" }; List<String> myList = Arrays.asList(myArray); //上面兩個語句等價于下面一條語句 List<String> myList = Arrays.asList("Apple","Banana", "Orange");

    JDK 源碼對于這個方法的說明:

    /***返回由指定數組支持的固定大小的列表。此方法作為基于數組和基于集合的API之間的橋梁,與 Collection.toArray()結合使用。返回的List是可序列化并實現RandomAccess接口。*/ public static <T> List<T> asList(T... a) {return new ArrayList<>(a); }

    《阿里巴巴 Java 開發手冊》對其的描述

    Arrays.asList()將數組轉換為集合后,底層其實還是數組,《阿里巴巴 Java 開發手冊》對于這個方法有如下描述:

    阿里巴巴Java開發手-Arrays.asList()方法

    使用時的注意事項總結

    傳遞的數組必須是對象數組,而不是基本類型。

    Arrays.asList()是泛型方法,傳入的對象必須是對象數組。

    int[] myArray = { 1, 2, 3 }; List myList = Arrays.asList(myArray); System.out.println(myList.size());//1 System.out.println(myList.get(0));//數組地址值 System.out.println(myList.get(1));//報錯:ArrayIndexOutOfBoundsException int [] array=(int[]) myList.get(0); System.out.println(array[0]);//1

    當傳入一個原生數據類型數組時,Arrays.asList() 的真正得到的參數就不是數組中的元素,而是數組對象本身!此時 List 的唯一元素就是這個數組,這也就解釋了上面的代碼。

    我們使用包裝類型數組就可以解決這個問題。

    Integer[] myArray = { 1, 2, 3 };

    使用集合的修改方法:add()、remove()、clear()會拋出異常。

    List myList = Arrays.asList(1, 2, 3); myList.add(4);//運行時報錯:UnsupportedOperationException myList.remove(1);//運行時報錯:UnsupportedOperationException myList.clear();//運行時報錯:UnsupportedOperationException

    Arrays.asList() 方法返回的并不是 java.util.ArrayList ,而是 java.util.Arrays 的一個內部類,這個內部類并沒有實現集合的修改方法或者說并沒有重寫這些方法。

    List myList = Arrays.asList(1, 2, 3); System.out.println(myList.getClass());//class java.util.Arrays$ArrayList

    下圖是java.util.Arrays$ArrayList的簡易源碼,我們可以看到這個類重寫的方法有哪些。

    private static class ArrayList<E> extends AbstractList<E>implements RandomAccess, java.io.Serializable{...@Overridepublic E get(int index) {...}@Overridepublic E set(int index, E element) {...}@Overridepublic int indexOf(Object o) {...}@Overridepublic boolean contains(Object o) {...}@Overridepublic void forEach(Consumer<? super E> action) {...}@Overridepublic void replaceAll(UnaryOperator<E> operator) {...}@Overridepublic void sort(Comparator<? super E> c) {...}}

    我們再看一下java.util.AbstractList的remove()方法,這樣我們就明白為啥會拋出UnsupportedOperationException。

    public E remove(int index) {throw new UnsupportedOperationException(); }

    總結

    以上是生活随笔為你收集整理的java list有序还是无序_牛批!2w字的Java集合框架面试题精华集(2020最新版),赶紧收藏。...的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    中文字幕国内精品 | 人人爽久久久噜噜噜电影 | 日韩av免费在线看 | 一区二区视频在线播放 | 国产夫妻自拍av | 久久国产片 | 久久一区二区免费视频 | 日韩欧美视频一区二区 | 九九热在线观看 | 国产又粗又猛又色又黄视频 | 国产精品永久久久久久久www | 国产精品国产三级国产aⅴ入口 | 免费激情在线电影 | 亚洲乱码精品久久久久 | 99久热在线精品视频成人一区 | 久久婷婷国产色一区二区三区 | 成人97视频一区二区 | 国产精品高潮在线观看 | 亚洲另类人人澡 | 亚洲91av| 毛片99 | 黄色免费观看视频 | 综合黄色网 | 狠狠操操 | 黄色av电影免费观看 | 久久精品视频免费播放 | 天天射天天爽 | 国产视频99 | 久久精品2 | 日日夜夜操操操操 | av在线a| 超碰激情在线 | 91女神的呻吟细腰翘臀美女 | 黄色精品在线看 | 亚洲综合情 | 久草综合视频 | 日韩高清黄色 | 成人av动漫在线 | 国产v在线观看 | 国产精品久久久久久久久久免费 | 久久免费成人精品视频 | 欧美 日韩 性| 国产精品久久久久久久妇 | 天天av资源| 久久一线 | 人人爽人人爽人人 | 午夜久久久精品 | 午夜精品一区二区三区四区 | 一级久久精品 | 成人一级在线观看 | 成人精品一区二区三区中文字幕 | 久久爱资源网 | 天天操人人要 | 欧美日韩在线视频观看 | 国产精品永久免费在线 | 国产精品中文字幕在线播放 | 国产不卡精品 | 精品色综合 | 国产视频不卡 | 国产精品18毛片一区二区 | 免费黄色小网站 | 91福利国产在线观看 | 激情av五月婷婷 | 天堂av免费在线 | 欧美精品一区二区蜜臀亚洲 | 在线观看精品视频 | 亚洲理论电影网 | 国产精品女同一区二区三区久久夜 | 久久这里只有精品视频99 | 视频精品一区二区三区 | 欧美日韩精品二区第二页 | 麻豆视频在线免费 | 青春草免费在线视频 | 国产精品观看视频 | 久久99国产精品视频 | www.五月天激情 | 午夜久草| 51精品国自产在线 | 久久一区二区免费视频 | 日韩av资源在线观看 | 亚洲精品乱码久久久久久按摩 | 日韩免费观看av | 日韩欧美精品一区 | 天天视频亚洲 | 亚洲精品男人的天堂 | 国产精美视频 | 欧美日韩午夜在线 | 麻豆传媒一区二区 | 91人人爱 | 欧美亚洲成人xxx | 在线观看免费版高清版 | 免费在线91 | 国产成人精品亚洲日本在线观看 | 欧美一级片免费在线观看 | 91av视频免费在线观看 | 人人干人人做 | 国产成人精品一区二区三区 | 中文字幕一区二区三区乱码在线 | 精品天堂av | 成人久久亚洲 | 国产精品免费小视频 | 久久久国产精品久久久 | 青春草免费在线视频 | 天天色天天射天天操 | 亚洲精品乱码久久久久久按摩 | 国产涩图 | 正在播放一区二区 | 91亚洲国产成人久久精品网站 | 精品一区二区视频 | 久久综合九色综合97_ 久久久 | 欧美日韩免费一区 | 17婷婷久久www | 国产偷国产偷亚洲清高 | 91免费高清| 亚洲精品成人在线 | 99热这里只有精品国产首页 | 欧美精品久久久久久 | 欧美一区在线观看视频 | 99视频在线精品免费观看2 | 9色在线视频 | 丰满少妇高潮在线观看 | 亚洲精品一区二区三区新线路 | 国产精品免费在线播放 | 欧美日韩亚洲国产一区 | 亚洲欧美婷婷六月色综合 | 综合网婷婷 | 天天插综合 | 国产精品一区二区视频 | 一二区精品| 亚洲视频axxx| 九九久久成人 | 成人av在线影院 | 四虎影视精品成人 | 美女免费视频网站 | 伊人五月天.com | 99一级片 | 日日夜夜精品视频天天综合网 | 日韩av午夜 | 国产伦理久久精品久久久久_ | 日韩91在线 | 97在线观看视频国产 | 国产123区在线观看 国产精品麻豆91 | 在线观看成人网 | 91人人爽久久涩噜噜噜 | 激情xxxx| 精品国产黄色片 | 国产一区二区三精品久久久无广告 | 国产一区精品在线观看 | 国产成人精品电影久久久 | 亚洲欧洲视频 | 国产在线观看a | 超碰在线人人 | 精品久久久久久久久久国产 | 免费在线观看成人av | 婷婷av资源 | 夜色成人网 | 日韩视频一 | 9797在线看片亚洲精品 | 91超级碰| 日韩精品一区二区三区水蜜桃 | 久久久久久毛片 | 毛片一级免费一级 | 久久视频这里有久久精品视频11 | 久久久精品一区二区 | 亚洲国产一二三 | 992tv人人草| 精油按摩av| 黄色a大片 | 黄色毛片在线观看 | av黄色在线观看 | 日本字幕网 | 91人人澡 | 99精品视频在线免费观看 | 天天艹| 欧美日高清视频 | 麻豆视频国产精品 | 免费看黄色毛片 | 国内精品视频在线 | 日韩免费在线观看视频 | 精品一区在线 | 久久99热这里只有精品国产 | 久久草av| 日韩动态视频 | av国产网站| 国产一区在线播放 | 96精品视频 | 精品国产综合区久久久久久 | 午夜精品一区二区三区在线观看 | 日韩精品视频免费专区在线播放 | 在线色资源 | 国内精自线一二区永久 | 日韩a在线播放 | 久久久久国产成人免费精品免费 | 欧美日韩不卡一区 | 久久人人精品 | 国产黄色片免费观看 | 日韩国产精品久久久久久亚洲 | 日韩欧美大片免费观看 | 久草在线精品观看 | 成人性生交大片免费观看网站 | 日韩最新av在线 | 亚洲国产大片 | 高清av网站| 亚洲人av免费网站 | 国产精品成人av在线 | 91亚洲精品久久久中文字幕 | 天天干天天操天天干 | 中文字幕一区二区三区在线视频 | 黄网站a | 成人久久18免费网站图片 | www.夜夜草 | 在线导航av | 中国精品一区二区 | 精品黄色在线观看 | 成人一级片视频 | 亚洲第一中文字幕 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 国产精品午夜久久 | 玖玖视频网| 天天色天天操天天爽 | 激情九九 | 最新国产精品久久精品 | 久久婷五月 | 国内精品视频一区二区三区八戒 | 天天射天天干天天插 | 黄色影院在线免费观看 | 日本护士三级少妇三级999 | 中文字幕免 | 日日爱网站 | 黄色一级大片在线免费看产 | 在线观看中文 | 国产又粗又长的视频 | 久久精品99国产精品酒店日本 | 在线三级播放 | 免费日韩三级 | 九九一级片 | 韩国av免费观看 | 日韩欧美国产精品 | 色婷婷狠狠 | 国产精品久久久久久久av大片 | 国产精品久久久久久一区二区三区 | 亚洲第一香蕉视频 | 天天色综合久久 | 视频在线一区二区三区 | 九九久久视频 | 在线精品播放 | 久久99偷拍视频 | 99视频99| 免费观看视频的网站 | 日韩精品中文字幕在线观看 | 一区二区在线不卡 | 日韩免费电影网站 | 一区二区三区在线观看免费 | 九九热国产视频 | 国产高清 不卡 | 中文字幕在线观看网站 | 亚洲精品一区二区三区高潮 | 亚洲精品视频www | 91成人免费电影 | 免费看污的网站 | 黄色毛片电影 | 欧美日韩在线播放 | 日韩免费视频一区二区 | 91久久国产综合精品女同国语 | 久久精品99久久久久久 | 国产精品18久久久久vr手机版特色 | 久久视频免费在线观看 | 久草视频视频在线播放 | 色多多在线观看 | 国产精品自产拍在线观看网站 | 性色xxxxhd| 五月丁色 | 亚洲精品乱码白浆高清久久久久久 | 国产精品密入口果冻 | 大荫蒂欧美视频另类xxxx | 日韩精品在线看 | 国产精品久久久电影 | 日本九九视频 | 亚洲 欧美 日韩 综合 | 国产国语在线 | 国产精品一区在线 | 天天综合色天天综合 | 奇米影视在线99精品 | www.91国产| wwxxxx日本 | 成人国产精品 | 婷婷深爱五月 | 国产综合婷婷 | av电影一区二区三区 | 国内视频在线 | 日韩高清一二三区 | 精品自拍av | 九草视频在线观看 | 国产精品99蜜臀久久不卡二区 | 中文字幕在线观看免费高清电影 | se婷婷| 91av在线免费看| 香蕉久久久久 | 国内久久视频 | 亚洲成人av影片 | 久久久久 免费视频 | av天天澡天天爽天天av | 亚洲老妇xxxxxx| 偷拍精品一区二区三区 | 免费一级片视频 | 91免费日韩 | 日韩视频中文字幕 | 国产精品久久久久一区二区三区 | 91av久久 | 欧美精品一区二区性色 | 国产精品刺激对白麻豆99 | 香蕉视频在线免费 | 亚洲精品免费看 | 992tv在线成人免费观看 | 久久精品成人欧美大片古装 | 久免费视频 | 五月综合婷 | 99精品亚洲| 亚洲mv大片欧洲mv大片免费 | 免费看的黄色网 | 婷五月天激情 | 欧美日本一二三 | 久久久久国产精品厨房 | 天天天天天天干 | 欧美电影在线观看 | 欧美在线视频免费 | 欧美激情精品久久久久 | 操操操日日 | 成人四虎影院 | 深爱激情综合 | 黄色精品久久久 | 97色在线观看 | 午夜视频二区 | 狠狠色丁香婷婷综合久久片 | 久草av在线播放 | 国产操在线 | 欧美淫aaa免费观看 日韩激情免费视频 | 黄色小说免费在线观看 | 日韩高清在线一区二区 | 九九九九九国产 | 91成人精品 | 人人狠狠| 99久久精品免费看国产一区二区三区 | 久久久男人的天堂 | 超碰在线99 | 国产精品美女久久久久久久 | 麻豆传媒电影在线观看 | 夜夜骑天天操 | 国产五月色婷婷六月丁香视频 | 亚洲麻豆精品 | 日韩av偷拍| 波多野结衣一区三区 | 99热只有精品在线观看 | 久久久国产精华液 | 手机看国产毛片 | 精品国产区 | 亚洲精品在线免费看 | 久久韩国免费视频 | 四虎永久精品在线 | 国产在线观看你懂的 | 国产精品丝袜久久久久久久不卡 | 精品国模一区二区三区 | 天天操天天色天天射 | 天天天综合网 | 中文字幕在线播放一区二区 | 国产免费观看高清完整版 | 六月婷婷网| 成片视频在线观看 | 91香蕉视频 mp4 | 欧美大片在线观看一区 | 性色av免费在线观看 | 国产精品美女毛片真酒店 | 狠狠干2018| 日本精品视频在线观看 | 成人av片在线观看 | 国产美女精品视频免费观看 | 综合网在线视频 | 正在播放国产91 | 久久久久国产成人免费精品免费 | 日韩av电影手机在线观看 | 国产剧情在线一区 | 九月婷婷色 | 99精品久久久久久久久久综合 | 免费视频一二三 | 国产精品免费不卡 | 91chinese在线| 超碰97国产精品人人cao | 蜜臀精品久久久久久蜜臀 | 久草在线电影网 | 天天综合天天做天天综合 | 国产精品18久久久久久久久久久久 | 91激情视频在线观看 | 久久毛片高清国产 | 成人激情开心网 | www.夜夜草 | 天天操天天操天天操天天操天天操 | 91精品伦理 | 精品国产一区二区三区久久久蜜月 | 免费观看黄色av | 婷婷精品国产一区二区三区日韩 | 久草综合在线观看 | 国产黄在线免费观看 | 国产黄色av网站 | 亚洲影院国产 | 国产亚州精品视频 | 久久天天躁夜夜躁狠狠85麻豆 | 久久久久久久久久亚洲精品 | 91久久精品一区二区三区 | 不卡精品视频 | 久久久精品亚洲 | 精品视频国产 | 国产一区二区三区高清播放 | 天天人人 | 久草在线免费在线观看 | 日韩免费不卡av | 91九色蝌蚪在线 | 成人网在线免费视频 | 天天做夜夜做 | 99视频一区| 国产精品久久久久久久久免费 | 国产一级片一区二区三区 | 国产一区高清在线 | 国产精品成人免费一区久久羞羞 | 日本视频不卡 | 伊人色综合久久天天 | 91最新地址永久入口 | 夜又临在线观看 | 国产精品成人自产拍在线观看 | 在线成人看片 | 亚洲日本激情 | 91丨九色丨蝌蚪丨老版 | 精品96久久久久久中文字幕无 | av在线播放不卡 | www.天天干.com | 久久久国产在线视频 | 久久一区国产 | 在线不卡中文字幕播放 | 91喷水 | 中文字幕二区在线观看 | 日日草天天草 | 三级性生活视频 | 天天干天天射天天爽 | 美女视频永久黄网站免费观看国产 | 久久国产剧场电影 | 国产原厂视频在线观看 | 久久久麻豆精品一区二区 | 色中色综合| 在线色资源 | 欧美一级片免费 | 亚洲精品国产精品国自产在线 | 99精品视频在线观看视频 | 国产在线美女 | 香蕉影视 | 欧美精品在线免费 | 久久99视频 | 久久精品久久久久 | 久久久久久久久久久久亚洲 | 日韩欧美精选 | 日本不卡123区 | 国产护士av | 91.麻豆视频 | 国产精品久久久久永久免费 | 国产不卡精品 | 亚洲一一在线 | www激情久久 | 国产第页 | 国产一区在线免费观看视频 | 99中文字幕在线观看 | 久久看看 | 日韩mv欧美mv国产精品 | 欧美色图亚洲图片 | 久久成人精品 | 欧美日韩视频 | 亚洲精品观看 | 亚洲网站在线看 | 亚洲综合视频在线 | 成人免费在线看片 | 亚洲精品国产区 | 天天操夜夜做 | 国产精品11 | 麻豆精品在线视频 | 99久久婷婷国产综合精品 | 国产在线a免费观看 | 白丝av在线| www.国产精品 | 特级西西www44高清大胆图片 | 超碰国产在线观看 | 免费性网站 | 四虎最新域名 | 国产91亚洲精品 | 九九免费精品视频在线观看 | 日韩免费一二三区 | 91最新视频在线观看 | 丁香婷婷激情网 | 97超碰色偷偷 | 久操中文字幕在线观看 | 国产亚洲婷婷 | 日韩一级电影网站 | 丰满少妇在线观看 | 日本性高潮视频 | 免费观看一区二区 | 久久精品三 | 五月婷婷视频在线 | www色片| 色综合久久久久综合体 | 午夜资源站 | 国产精品观看视频 | 欧美精品乱码99久久影院 | 日韩av一区二区三区四区 | 久久精国产 | 国产又粗又猛又爽又黄的视频免费 | 波多野结衣网址 | 亚洲电影第一页av | 欧美日韩中文字幕视频 | 婷婷在线播放 | 激情av网| 中文 一区二区 | 久久成人免费视频 | 色a综合 | 免费麻豆| 成年人免费看片 | 麻豆视频免费版 | 日韩久久激情 | 成人h在线| 色姑娘综合天天 | 欧美激情亚洲综合 | 日韩中文字幕在线观看 | 最新中文字幕在线观看视频 | 欧美性生活久久 | 久久国产精品一区二区三区四区 | 男女免费视频观看 | 欧美性极品xxxx娇小 | 久久久国产精品麻豆 | 五月婷婷国产 | 网址你懂的在线观看 | 三级a视频 | 欧美日韩中文字幕视频 | 精品国产亚洲一区二区麻豆 | 在线播放你懂 | 在线国产一区二区 | 国产一区视频在线观看免费 | 国产成人a亚洲精品v | 亚洲国产精品久久久 | 午夜国产在线观看 | 六月丁香激情网 | 激情黄色一级片 | 人人干在线 | 五月婷婷激情 | 亚洲成av人片 | 久久经典国产 | 久久久精品高清 | 国产精品s色 | 丝袜制服天堂 | 免费观看一区 | 亚洲国产日韩在线 | 人人爱人人舔 | 欧美老少交 | 激情综合电影网 | 成人av教育 | 欧美最新大片在线看 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 九九免费在线观看 | www.五月激情.com| 国产精品欧美久久久久无广告 | 美女免费视频一区 | 国产午夜精品免费一区二区三区视频 | 亚洲男男gaygay无套同网址 | 日本女人的性生活视频 | 91麻豆精品国产91久久久使用方法 | 久久九九影院 | 97精品国自产拍在线观看 | 成人久久久久久久久久 | 久操视频在线播放 | 欧美日韩久久不卡 | 97国产电影 | 日产乱码一二三区别免费 | 国产精品一区二区无线 | 日本午夜在线观看 | 国产成人一区二区三区在线观看 | 亚欧洲精品视频在线观看 | 国产精品美女免费 | 久久夜夜爽 | 一级黄色片毛片 | 色综合激情网 | 国产精品国产亚洲精品看不卡 | 精品视频久久久 | 97香蕉久久超级碰碰高清版 | 天天干,天天操,天天射 | 久热免费 | 亚洲成色777777在线观看影院 | 亚洲国产一区在线观看 | 久久人人干 | 亚洲精品久久久久久久不卡四虎 | 国产精品专区h在线观看 | 国产精品精品国产 | 你操综合| 国产精品网红福利 | 夜色.com| 欧美日韩中文国产 | 久久免费毛片 | 亚洲做受高潮欧美裸体 | 国产精品成人一区二区三区吃奶 | 久久艹在线观看 | 国产精品v欧美精品 | 亚洲视频在线免费看 | 国产精品成人av久久 | 天天射天天干 | 天天综合人人 | 亚洲妇女av | 日韩精品在线免费播放 | 香蕉视频18 | 91色亚洲| 啪啪小视频网站 | 伊人天天综合 | 日韩精品久久久久久 | 亚洲九九九在线观看 | av中文字幕在线播放 | 国产亚洲视频在线观看 | 丁香六月婷婷开心婷婷网 | www免费视频com━ | 国产综合片 | 欧美91av| 国产成人av网 | 在线观看亚洲精品视频 | 国产精品永久久久久久久www | 正在播放亚洲精品 | 五月婷综合 | 日本最新一区二区三区 | 成人av高清在线 | 久久精品专区 | 奇米网8888 | 婷婷丁香色 | 亚洲经典视频 | 久久精品国产成人 | 五月综合在线观看 | 成人网中文字幕 | 五月婷婷色播 | 在线观看欧美成人 | 在线国产一区二区 | 一二区av | 99自拍视频在线观看 | 99r在线播放 | 免费视频91蜜桃 | 中文字幕在线观看视频网站 | 夜色资源网 | 五月网婷婷 | 国产精品免费人成网站 | 午夜精品99久久免费 | 国产伦精品一区二区三区无广告 | 日产乱码一二三区别免费 | 国产精品观看在线亚洲人成网 | 白丝av在线 | 九七视频在线观看 | 91视频亚洲| 在线色吧| 黄网站色| 欧美激情视频一二三区 | 中文字幕一区二区三区四区 | 中国一级片在线观看 | 国产成人免费网站 | 日韩欧美一区二区三区在线观看 | 九草在线视频 | 亚州av成人 | 丰满少妇在线观看 | 五月开心婷婷网 | 在线日本看片免费人成视久网 | 久久激情五月婷婷 | 日韩电影一区二区在线 | 日韩免费不卡av | 狠狠色噜噜狠狠狠合久 | 一区二区三区动漫 | 欧美日韩视频在线观看一区二区 | 99久久精品日本一区二区免费 | 欧美男男tv网站 | 激情综合网色播五月 | 国产麻豆电影在线观看 | 波多野结衣在线播放一区 | 天天干天天干天天干天天干天天干天天干 | 日日干夜夜干 | 日韩欧美在线观看一区 | 黄色一级免费电影 | 亚洲视频免费视频 | 国产在线免费观看 | 免费日韩一区二区三区 | 夜夜躁日日躁 | 97色综合| 就操操久久 | 免费a视频在线观看 | 日本久久影视 | 国产精品久久网 | 国产精品成久久久久三级 | 网址你懂的在线观看 | 狠狠色丁香久久婷婷综合_中 | 日韩欧美电影在线观看 | 黄色资源在线 | 成人羞羞免费 | 91九色视频在线观看 | 婷婷久月 | 成人黄色在线 | 在线观看中文字幕 | 欧美日韩电影在线播放 | 久久视频免费在线 | 最新影院 | 国产伦理精品一区二区 | 婷婷九九| 最近中文字幕mv免费高清在线 | 国产成人一区二区三区久久精品 | 丁香婷婷在线观看 | 亚洲天堂网在线视频 | 91麻豆精品国产91久久久久久久久 | 亚洲va天堂va欧美ⅴa在线 | 日韩羞羞| 欧美欧美 | 99久久久成人国产精品 | 欧美日韩一级久久久久久免费看 | 免费在线h | 日韩欧美精品在线 | 91看片成人| 久久无码精品一区二区三区 | 日韩丝袜在线 | 国产又粗又猛又色又黄网站 | 日产乱码一二三区别在线 | 九九久久久久久久久激情 | 国产精品24小时在线观看 | 久久影院一区 | 亚洲日本在线视频观看 | 欧美久久久久 | av大全在线免费观看 | 中文字幕在线观 | 久久久久国产一区二区 | 亚洲天堂网站视频 | 亚洲成人精品久久久 | 国产手机精品视频 | 99久久久国产精品免费观看 | 日韩精品中文字幕av | 久久久免费少妇 | 一区二区视频在线看 | 国产中文在线字幕 | 欧美日韩亚洲精品在线 | 久久人91精品久久久久久不卡 | 视频国产精品 | 丁香婷婷色月天 | 久久亚洲精品电影 | 最新国产精品拍自在线播放 | 亚洲免费一级 | 亚洲黄色激情小说 | 美女网站免费福利视频 | av在线网站免费观看 | 六月久久婷婷 | 在线亚洲欧美视频 | 东方av免费在线观看 | 亚洲欧美成人在线 | 日躁夜躁狠狠躁2001 | 97精品国产aⅴ | 久久午夜视频 | 国产精品久久久久久久久蜜臀 | 97成人精品区在线播放 | 国产小视频免费观看 | 亚洲黄色软件 | 91爱爱视频 | 精品日韩在线一区 | 精品视频久久 | 国产精品原创av片国产免费 | 国产一区二区三区高清播放 | www.黄色网.com | 精品亚洲免a | 欧美中文字幕第一页 | 日韩欧美视频在线 | 免费三级网 | 四虎国产精 | 亚洲欧美日韩不卡 | 国产日韩欧美中文 | 日本精品视频一区 | 毛片永久新网址首页 | 91福利小视频 | 91最新国产| 久久这里只有精品久久 | 99爱国产精品 | 国产精品一区二区三区在线看 | 精品av网站| 国产精品xxxx18a99 | 免费观看成人 | 天天干com | av 一区二区三区四区 | 成人午夜黄色 | 91视频大全 | 亚洲人天堂| 九9热这里真品2 | 在线国产激情视频 | 久久久久福利视频 | 久久艹人人| 一本一道久久a久久综合蜜桃 | 精品久久久久久久久久 | 国精产品999国精产品视频 | 五月开心色 | 九九久久电影 | 成人在线免费视频观看 | 在线观看久久 | 激情综合五月婷婷 | 99热99热| 亚洲作爱视频 | 美女久久久久久久久久 | 国内精品久久久久久久久久久久 | 亚洲区另类春色综合小说校园片 | 五月婷社区 | 手机在线小视频 | 亚洲精品视频免费在线 | 色婷婷视频网 | 亚洲欧洲精品一区 | 亚洲精品国精品久久99热一 | 久久99精品国产麻豆婷婷 | 日本黄色一级电影 | 人人爱人人做人人爽 | 午夜av大片 | 日本精品一 | 久久av免费 | 国产情侣一区 | 亚洲精品福利在线观看 | 中文在线中文a | 深爱婷婷| 在线 影视 一区 | 狠狠躁日日躁狂躁夜夜躁av | 久久影院午夜论 | 国产精品观看视频 | 欧美精品色 | 国产精品福利无圣光在线一区 | 激情五月开心 | 日韩精品久久久久 | 五月天六月色 | 国产视频在线观看一区二区 | www.久草视频 | 日韩大片在线播放 | 国产免费观看视频 | 日本一区二区三区视频在线播放 | 日韩一级黄色av | 国产精品欧美日韩在线观看 | 超碰伊人网 | 亚洲精品久久久久999中文字幕 | 麻豆高清免费国产一区 | 91av国产视频 | 黄网站大全 | 亚洲欧美va | 国产成人一级 | 福利视频区 | 一级一级一片免费 | 天天草天天操 | 精品在线看 | 麻豆首页| 日韩精品一卡 | 日韩免费视频在线观看 | 国产分类视频 | 蜜桃av久久久亚洲精品 | 久草在线视频首页 | 一区二区三区日韩在线观看 | 亚洲日本中文字幕在线观看 | 国产精品不卡在线 | 午夜精品久久久久久久久久久久 | 久久国产精品99久久人人澡 | 精品一区二区在线看 | 麻豆视频成人 | 在线播放国产一区二区三区 | 玖玖视频网 | 国产精品一区免费观看 | 亚洲a成人v | 亚洲精品乱码久久 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 蜜臀av夜夜澡人人爽人人 | 97精品一区二区三区 | 欧美日韩免费观看一区=区三区 | 精品国内自产拍在线观看视频 | 国产精品日韩在线播放 | 欧美中文字幕久久 | 欧美美女激情18p | 国产中文在线视频 | 在线91精品| 成人黄色电影在线观看 | 麻豆免费视频观看 | 国产99久久久精品视频 | 91av手机在线观看 | 免费观看国产精品视频 | 激情黄色av | 成人久久久久久久久久 | 国产特黄色片 | 久久综合九色综合网站 | 夜夜操天天干, | 操久久免费视频 | 麻豆91在线看 | 久久精品久久久久 | 精品少妇一区二区三区在线 | 国产码电影 | 精品1区二区 | 成人97视频一区二区 | 在线精品视频免费播放 | 亚洲精品三级 | 色瓜| 日韩毛片在线一区二区毛片 | 国模吧一区 | 欧美日产在线观看 | www.夜夜操.com | 亚洲免费小视频 | 久草在线电影网 | 国产中文伊人 | 91麻豆精品国产91久久久久久久久 | 亚洲精品美女久久久久网站 | 成人高清在线 | 人人狠 | 国产成人一区三区 | 中文字幕在线免费观看视频 | 91精品秘密在线观看 | 亚洲精品一区二区三区在线观看 | 麻豆精品视频在线观看免费 | 日韩av在线一区二区 | 全黄色一级片 | 久久人人97超碰精品888 | 亚洲深夜影院 | 在线观看网站黄 | 久草在线中文视频 | 伊人久久影视 | 在线精品国产 | 天天av资源| 日韩成人邪恶影片 | 国产成人精品999 | 国产三级香港三韩国三级 | 欧美色图亚洲图片 | 免费视频 你懂的 | 亚洲高清在线 | 成人久久免费视频 | 精品国产午夜 | 97视频资源| av品善网| 玖玖视频精品 | 日韩动态视频 | 成在线播放 | 国产成人777777 | 去看片 | 天天射综合网视频 | 天天操天天干天天玩 | 香蕉网站在线观看 | 免费看国产黄色 | 国产99久久久久久免费看 | 欧美一区二区三区在线视频观看 | 伊甸园永久入口www 99热 精品在线 | 日韩欧美在线不卡 | 日日夜夜天天综合 | 欧美日韩aa | 激情综合网五月婷婷 | 国产亚洲精品xxoo | 国产一区二区三区午夜 | 81国产精品久久久久久久久久 | 国产又粗又猛又色又黄网站 | 国产精品视频不卡 | 丝袜av网站| 在线观看中文字幕第一页 | 91一区啪爱嗯打偷拍欧美 | 91九色蝌蚪视频在线 | 久久视频免费在线 | 国产黄色电影 | 一区二区电影网 | 丁香激情五月婷婷 | 国产青草视频在线观看 | 久久精品影片 | 在线色亚洲 | 久久精品视频日本 | 99精品在线免费视频 | 99热 精品在线 | 亚州激情视频 | www.国产在线| 不卡视频国产 | 日韩精品久久久久久久电影99爱 | 在线播放日韩av | 中文字幕第一页在线vr | 日韩毛片精品 | 亚洲精品乱码久久久久久 | 久久色视频 | 国产精品女 | 国内一级片在线观看 | 国产99免费视频 | 国产精品一区二区三区久久 | 国产精品人人做人人爽人人添 | 亚洲精品乱码白浆高清久久久久久 | 国产乱码精品一区二区三区介绍 | 久久涩涩网站 | 亚洲欧美日韩精品一区二区 | 欧美激情另类 | 久热色超碰 | 亚洲aⅴ乱码精品成人区 | 国产婷婷精品 | 中文字幕免费看 | 国产精品18久久久久久vr | 黄色在线免费观看网址 | 97av在线 | 91视频免费网址 | 狠狠色噜噜狠狠狠狠2021天天 | 国产裸体视频网站 | 午夜国产在线 | 免费在线视频一区二区 | 天天射天天操天天干 | 色偷偷88888欧美精品久久 |