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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java集合框架的结构_集合框架(Collections Framework)详解及代码示例

發(fā)布時間:2023/12/4 编程问答 65 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java集合框架的结构_集合框架(Collections Framework)详解及代码示例 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

簡介

集合和數(shù)組的區(qū)別:

數(shù)組存儲基礎(chǔ)數(shù)據(jù)類型,且每一個數(shù)組都只能存儲一種數(shù)據(jù)類型的數(shù)據(jù),空間不可變。

集合存儲對象,一個集合中可以存儲多種類型的對象。空間可變。

嚴格地說,集合是存儲對象的引用,每個對象都稱為集合的元素。根據(jù)存儲時數(shù)據(jù)結(jié)構(gòu)的不同,分為幾類集合。但對象不管存儲到什么類型的集合中,既然集合能存儲任何類型的對象,這些對象在存儲時都必須向上轉(zhuǎn)型為Object類型,也就是說,集合中的元素都是Object類型的對象。

既然是集合,無論分為幾類,它都有集合的共性,也就是說雖然存儲時數(shù)據(jù)結(jié)構(gòu)不一樣,但該有的集合方法還是得有。在java中,Collection接口是集合框架的根接口,所有集合的類型都實現(xiàn)了此接口或從其子接口中繼承。

Collection接口

根據(jù)數(shù)據(jù)結(jié)構(gòu)的不同,一些collection允許有重復(fù)的元素,而另一些則不允許。一些collection是有序的,而另一些則是無序的。

Java SDK不提供直接繼承自Collection的類,Java SDK提供的類都是繼承自Collection的"子接口"如List和Set。也就是說,無法直接new一個collection對象,而是只能new一個實現(xiàn)Collection類的子接口的對象,如new ArrayList();。

所有的Collection類都必須至少提供兩個構(gòu)造方法:無參數(shù)構(gòu)造方法構(gòu)造一個空集合;帶Collection參數(shù)的構(gòu)造方法構(gòu)造一個包含該Collection內(nèi)容的集合。例如,ArrayList就有3個構(gòu)造方法,其中之二就滿足這兩個構(gòu)造方法的要求。

Collection是java.util包中的類,因此要實現(xiàn)集合的概念,需要先導(dǎo)入該包。

ArrayList繼承自List接口,List接口又繼承自Collection接口。ArrayList類存儲的集合中,元素有序、可重復(fù)。

import java.util.*;

Collection coll = new ArrayList();

因為Collection接口不允許直接實現(xiàn),因此需要通過實現(xiàn)它的子類來實現(xiàn)集合的概念,此處創(chuàng)建的是ArrayList對象,使用了父類引用,好處是擴展性較好。

Collection有一些集合的通用性操作方法,分為兩類:一類是普通方法;一類是帶有All的方法,這類方法操作的是集合。

add():向集合的尾部插入元素,返回值類型為boolean,插入成功返回true。注意集合只能存儲對象(實際上是對象的引用)。

import java.util.*;

//

public class TestColl {

public static void main(String[] args) {

Collection coll = new ArrayList();

coll.add("abcd");

//插入字符串對象

coll.add(123);

//插入Int對象

coll.add(123);

coll.add(new Student("Gaoxiaof",23));

//插入Student對象

coll.add(new Student("Gaoxiaof",23));

//插入另一個Student對象

System.out.println(coll);

//直接輸出集合中的元素,得到結(jié)果[abcd,123,123,Gaoxiaof 23,Gaoxiaof 23]

}

}

//

class Student {

private String name;

private int age;

Student(String name,int n) {

this.name = name;

this.age = n;

}

public String getName() {

return this.name;

}

public int getAge() {

return this.age;

}

public String toString() {

return this.name + " " + this.age;

}

}

上面插入的"abcd"和"123"都是經(jīng)過自動裝箱轉(zhuǎn)換為對象后存儲在集合中的。其中兩個add(123)是重復(fù)的對象元素,因為判斷集合中的元素是否重復(fù)的唯一方法是equals方法是否返回0。Integer已經(jīng)重寫過equals()。而后面的兩個Student對象是不同對象,因為Student類中沒有重寫equals()方法,所以它們是不重復(fù)的元素。

remove():刪除集合中首次出現(xiàn)的元素。確定是否能刪除某個元素,唯一的方法是通過equals()方法確定對象是否相等,相等時刪除才返回true。

Collection coll = new ArrayList();

coll.add("abcd");

coll.add(new Integer(128));

coll.add(new Student("Gaoxiaofang",23));

System.out.println(coll.remove(new Integer(128))); //true

coll.remove(new Student("Gaoxiaofang",23)); //false,因為沒有重寫equals()

System.out.println(coll); //return: [abcd,Gaoxiaofang 23]

clear():清空該集合中的所有元素。

contains(object obj):是否包含某對象元素。判斷的依據(jù)仍然是equals()方法。

Collection coll = new ArrayList();

coll.add(new Integer(128));

System.out.println(coll.contains(new Integer(128))); //true

isEmpty():集合是否不包含任何元素。

size():返回該集合中元素的個數(shù)。

equals(Object obj):比較兩個集合是否完全相等。依據(jù)是集合中的所有元素都能通過各自的equals得到相等的比較。

addAll(Collection c):將整個集合c中的元素都添加到該集合中。

containsAll(Collection c):該集合是否包含了c集合中的所有元素,即集合c是否是該集合的子集。

removeAll(Collection c):刪除該集合中那些也包含在c集合中的元素。即刪除該集合和c集合的交集元素。

retainAll(Collection c):和removeAll()相反,僅保留該集合中和集合c交集部分的元素。

iterator(Collection c):返回此集合中的迭代器,注意返回值類型為Iterator。迭代器用于遍歷集合。見下文。

Iterator通用迭代器

因為不同類型的集合存儲數(shù)據(jù)時數(shù)據(jù)結(jié)構(gòu)不同,想要寫一個通用的遍歷集合的方法是不現(xiàn)實的。但無論是哪種類型的集合,只有集合自身對集合中的元素是最了解的,因此在實現(xiàn)Collection接口時,不同集合類都實現(xiàn)了自己獨有的遍歷方法,這稱為集合的迭代器Iterator。其實Collection繼承了java.lang.Iterable接口,該接口只提供了一個方法:iterator(),只要是實現(xiàn)了這個接口的類就表示具有迭代的能力,也就具有foreach增強遍歷的能力。

迭代器自身是一個接口,通過Collection對象的iterator()方法就可以獲取到對應(yīng)集合類型的迭代器。例如:

Collection coll = new ArrayList();

Iterator it = coll.iterator(); //獲取對應(yīng)類型的集合的迭代器

Iterator接口提供了3個方法:

hasNext():判斷是否有下一個元素。

Next():獲取下一個元素。注意它返回的是Object(暫不考慮泛型)類型。

remove():移除迭代器最后返回的一個元素。此方法為Collection迭代過程中修改元素的唯一安全的方法。

雖然有不同種類型的集合,但迭代器的迭代方法是通用的。例如,要遍歷coll集合中的元素。

import java.util.*;

public class TestColl {

public static void main(String[] args) {

Collection coll = new ArrayList();

coll.add("abcd");

coll.add(new Integer(129));

coll.add(new Student("Gaoxiaofang",23));

Iterator it = coll.iterator();

while (it.hasNext()) { //Iterator遍歷的方法

System.out.println(it.next()); //return:abcd,129,Gaoxiaofang 23

}

}

}

class Student {

private String name;

private int age;

Student(String name,int n) {

this.name = name;

this.age = n;

}

public String getName() {

return this.name;

}

public int getAge() {

return this.age;

}

public String toString() {

return this.name + " " + this.age;

}

}

但是通常來說,上面的遍歷方式雖然正確,但下面的遍歷方式更佳。因為it對象只用于集合遍歷,遍歷結(jié)束后就應(yīng)該消失,所以將其放入到for循環(huán)的內(nèi)部,由于for循環(huán)的第三個表達式缺失,所以不斷地循環(huán)第二個表達式即可。

for (Iterator it = coll.iterator();it.hasNext();) {

System.out.println(it.next());

}

通過Iterator遍歷到的元素是集合中的一個對象,對象也是有屬性的。如何引用這些屬性?只需將遍歷出的元素作為對象來使用即可,但由于next()返回的元素都是Object對象,直接操作這個元素對象無法獲取對應(yīng)元素中的特有屬性。因此必須先強制對象類型轉(zhuǎn)換。

例如,獲取coll中為Student對象元素的name屬性,并刪除非Student對象的元素。

Collection coll = new ArrayList();

coll.add("abcd");

coll.add(new Integer(129));

coll.add(new Student("Gaoxiaofang",23));

for (Iterator it = coll.iterator();it.hasNext();) {

Object obj = it.next();

if (obj instanceof Student) {

Student s = (Student)obj;

System.out.println(s.getName()); //return: Gaoxiaofang

} else {

it.remove();

}

}

System.out.println(coll); //return: [Gaoxiaofang 23]

因為集合中有些非Student對象元素,因此需要判斷it.next()是否滿足instanceof的要求,但不能直接寫為下面的代碼:

for (Iterator it = coll.iterator();it.hasNext();) {

if (it.next() instanceof Student) {

Student s = (Student)it.next();

System.out.println(s.getName());

}

}

因為每執(zhí)行一次it.next(),元素的游標(biāo)指針就向下滑動1,在這個寫法中if判斷表達式中使用了一次it.next(),在if的代碼塊中又調(diào)用了一次it.next()。所以應(yīng)該將it.next()保存到對象變量中。而it.next()返回的類型是Object類型,因此定義Object obj = it.next()。

只有remove()方法是Iterator迭代器迭代過程中修改集合元素且安全的方法。以迭代時add()為例,當(dāng)開始迭代時,迭代器線程獲取到集合中元素的個數(shù),當(dāng)?shù)^程中執(zhí)行add()時,它將采用另一個線程來執(zhí)行(因為add()方法不是Iterator接口提供的方法),結(jié)果是元素個數(shù)就增加了,且導(dǎo)致新增的元素?zé)o法確定是否應(yīng)該作為迭代的一個元素。這是不安全的行為,因此會拋出ConcurrentModificationException異常。而remove()方法是迭代器自身的方法,它會使用迭代器線程來執(zhí)行,因此它是安全的。

對于List類的集合來說,可以使用Iterator的子接口ListIterator來實現(xiàn)安全的迭代,該接口提供了不少增刪改查List類集合的方法。

List接口

List接口實現(xiàn)了Collection接口。

List接口的數(shù)據(jù)結(jié)構(gòu)特性是:

1.有序列表,且?guī)饕齣ndex。所謂有序指先后插入的順序,即Index決定順序。而向Set集合中插入數(shù)據(jù)會被打亂

2.大小可變。

3.數(shù)據(jù)可重復(fù)。

4.因為有序和大小可變,使得它除了有Collection的特性,還有根據(jù)index精確增刪改查某個元素的能力。

5.實現(xiàn)List接口的兩個常用類為:

(1).ArrayList:數(shù)組結(jié)構(gòu)的有序列表;

1).長度可變,可變的原因是在減少或添加元素時部分下標(biāo)整體減一或加一,如果已分配數(shù)組空間不夠,則新創(chuàng)建一個更大的數(shù)組,并拷貝原數(shù)組的內(nèi)存(直接內(nèi)存拷貝速度極快);

2).查詢速度快,增刪速度慢。查詢快是因為內(nèi)存空間連續(xù),增刪速度慢是因為下標(biāo)移動。

3).除了ArrayList是不同步列表,它幾乎替代了Vector類。

(2).LinkedList:鏈表結(jié)構(gòu)的有序列表;

1).不同步;

2).增刪速度快,查詢速度慢。增刪速度快的原因是只需修改下鏈表中前后兩個元素的索引指向即可;

3).能夠?qū)崿F(xiàn)堆棧(后進先出LIFO,last in first out)、隊列(queue,通常是FIFO,first in first out)和雙端隊列(double ends queue)。

ArrayList類的方法和List方法基本一致,所以下面介紹了List通用方法和ListIterator就沒必要介紹ArrayList。但LinkedList比較特殊,所以獨立介紹。

List接口通用方法

除了因為繼承了Collection而具有的通用方法外,對于List接口也有它自己的通用方法。一般List的這些通用方法針對的是序列的概念。有了序列和下標(biāo)索引值,可以精確地操控某個位置的元素,包括增刪改查。

(1).增:add(index,element)

(2).刪:remove(index)、remove(obj)刪除列表中第一個obj元素

(3).改:set(index,element)

(4).查:get(index)

(5).indexOf(obj):返回列表中第一次出現(xiàn)obj元素的索引值,如不存在則返回-1

(6).lastIndexOf(obj)

(7).subList(start,end):返回列表中從start到end(不包括end邊界)中間的元素組成列表。注意返回的是List類型。

(8).listIterator():返回從頭開始遍歷的List類集合的迭代器ListIterator。

(9).listIterator(index):返回從index位置開始遍歷的List結(jié)合迭代器ListIterator。

因為有了get()方法,除了Iterator迭代方式,還可以使用get()方法遍歷集合:

List l = new ArrayList();

for (int i=0;i

System.out.println(l.get(i));

}

但注意,這種方法不安全,因為l.size()是即時改變的,如果增刪了元素,size()也會隨之改變。

示例:

import java.util.*;

public class TestList {

public static void main(String[] args) {

List ls = new ArrayList();

ls.add(new Student("Malong1",21));

ls.add(new Student("Malong2",22));

ls.add(1,new Student("Malong3",23));

//[Malong1 21,Malong3 23,Malong2 22]

System.out.println(ls.indexOf(new Student("Malong3",23)));

// return:1

ls.set(2,new Student("Gaoxiao1",22));

//[Malong1 21,Malong3 23,Gaoxiao1 22]

for (Iterator it = l.iterator();it.hasNext();) {

//第一種迭代

Student stu = (Student)it.next();

if (stu.getAge() == 22) {

it.remove();

// the safe way to operate element

//ls.add(new Student("Malong4",24)); //throw ConcurrentModificationException

}

}

//[Malong1 21,Malong3 23]

System.out.println(l+"\n---------------");

for (int i=0;i

//第二種迭代

System.out.println(ls.get(i));

}

}

}

class Student {

private String name;

private int age;

Student(String name,int n) {

this.name = name;

this.age = n;

}

public String getName() {

return this.name;

}

public int getAge() {

return this.age;

}

//override toString()

public String toString() {

return this.name + " " + this.age;

}

//override equals()

public Boolean equals(Object obj) {

if (this == obj) {

return true;

}

if (!(obj instanceof Student)) {

throw new ClassCastException("Class error");

}

Student stu = (Student)obj;

return this.name.equals(stu.name) && this.age == stu.age;

}

}

上面的代碼中,如果將ls.add(new Student("Malong4",24));的注釋取消,將拋出異常,因為Iterator迭代器中唯一安全操作元素的方法是Iterator接口提供的remove(),而add()方法是List接口提供的,而非Iterator接口的方法。但對于List集合類來說,可以使用ListIterator迭代器,它提供的操作元素的方法更多,因為是迭代器提供的方法,因此它們操作元素時都是安全的。

List集合的迭代器ListIterator

通過listIterator()方法可以獲取ListIterator迭代器。該迭代器接口提供了如下幾種方法:

hasNext():是否有下一個元素

hasPrevious():是否有前一個元素,用于逆向遍歷

next():獲取下一個元素

previour():獲取前一個元素,用于逆向遍歷

add(element):插入元素。注:這是迭代器提供的add(),而非List提供的add()

remove():移除next()或previous()獲取到的元素。注:這是迭代器提供的remove(),而非List提供的remove()

set(element):設(shè)置next()或previour()獲取到的元素。注:這是迭代器提供的set(),而非List提供的set()

例如:前文示例在Iterator迭代過程中使用List的add()添加元素拋出了異常,此處改用ListIterator迭代并使用ListIterator提供的add()方法添加元素。

List l = new ArrayList();

l.add(new Student("Malong1",21));

l.add(new Student("Malong2",22));

l.add(1,new Student("Malong3",23)); //[Malong1 21,Malong3 23,Malong2 22]

l.set(2,new Student("Gaoxiao1",22));//[Malong1 21,Malong3 23,Gaoxiao1 22]

for (ListIterator li = l.listIterator();li.hasNext();) {

Student stu = (Student)li.next();

if (stu.getAge() == 22) {

//l.add(new Student("Malong4",24)); //throw ConcurrentModificationException

li.add(new Student("Malong4",24));

}

}

LinkedList集合

LinkedList類的數(shù)據(jù)結(jié)構(gòu)是鏈表類的集合。它可以實現(xiàn)堆棧、隊列和雙端隊列的數(shù)據(jù)結(jié)構(gòu)。其實實現(xiàn)這些數(shù)據(jù)結(jié)構(gòu)都是通過LinkedList提供的方法按照不同邏輯實現(xiàn)的。

提供的其中幾個方法如下:因為是實現(xiàn)了List接口,所以除了下面的方法,還有List接口的方法可用。

addFirst(element):向鏈表的首部插入元素

addLast(element):向鏈表的尾部插入元素

getFirst():獲取鏈表的第一個元素

getLast():獲取鏈表最后一個元素

removeFirst():移除并返回第一個元素,注意返回的是元素

removeLast():移除并返回最后一個元素,注意返回的是元素

LinkedList模擬隊列數(shù)據(jù)結(jié)構(gòu)

隊列是先進先出FIFO的數(shù)據(jù)結(jié)構(gòu)。封裝的隊列類MyQueue代碼如下:

import java.util.*;

class MyQueue {

private LinkedList mylist;

MyQueue() {

mylist = new LinkedList();

}

// add element to queue

public void add(Object obj) {

mylist.addFirst(obj);

//Fisrt In

}

//get element from queue

public Object get() {

return mylist.removeLast();

//First Out

}

//queue is null?

public Boolean isNull() {

return mylist.isEmpty();

}

//the size of queue

public int size() {

return mylist.size();

}

//remove element in queue by index

public Boolean remove(int index) {

if(this.size()-1 < index) {

throw new IndexOutOfBoundsException("index too large!");

}

mylist.remove(index);

return true;

}

//remove the first appearance element in queue by Object

public Boolean remove(Object obj) {

return mylist.remove(obj);

}

public String toString() {

return mylist.toString();

}

}

操作該隊列數(shù)據(jù)結(jié)構(gòu)程序代碼如下:

import java.util.*;

public class FIFO {

public static void main(String[] args) {

MyQueue mq = new MyQueue();

mq.add("Malong1");

mq.add("Malong2");

mq.add("Malong3");

mq.add("Malong4"); //[Malong4,Malong3,Malong2,Malong1]

System.out.println(mq.size()); //return:4

mq.remove(2); //[Malong4,Malong3,Malong1]

mq.remove("Malong1"); //[Malong4,Malong3]

System.out.println(mq);

while (!mq.isNull()) {

System.out.println(mq.get());

}

}

}

Set接口

Set接口也實現(xiàn)了Collection接口。它既然能單獨成類,它和List集合的數(shù)據(jù)結(jié)構(gòu)一定是大有不同的。

Set接口的數(shù)據(jù)結(jié)構(gòu)特性是:

1.Set集合中的元素?zé)o序。這里的無序是相對于List而言的,List的有序表示有下標(biāo)Index的順序,而Set無需是指沒有index也就沒有順序。

2.Set集合中的元素不可重復(fù)。

3.因為無序,因此Set集合中取出元素的方法只有一種:迭代。

4.實現(xiàn)Set接口的兩個常見類為:

(1).HashSet:hash表數(shù)據(jù)結(jié)構(gòu);

1).不同步;

2).查詢速度快;

3).判斷元素是否重復(fù)的唯一方法是:先調(diào)用hashcode()判斷對象是否相同,相同者再調(diào)用equals()方法判斷內(nèi)容是否相同。所以,要將元素存儲到此數(shù)據(jù)結(jié)構(gòu)的集合中,必須重寫hashcode()和equals()。

(2).TreeSet:二叉樹數(shù)據(jù)結(jié)構(gòu);

1).二叉樹是用來排序的,因此該集合中的元素是有序的。這個有序和List的有序概念不同,此處的有序指的是存儲時對元素進行排序,例如按照字母順序,數(shù)字大小順序等,而非index索引順序。

2).既然要排序,而equals()方法只能判斷是否相等。因此數(shù)據(jù)存儲到TreeSet集合中時需要能夠判斷大小。

3).有兩種方法用于構(gòu)造有序的TreeSet集合:

a.待存儲對象的類實現(xiàn)Comparable接口并重寫它的compareTo()方法;

b.在構(gòu)造TreeSet集合時指定一個比較器comparator。這個比較器需要實現(xiàn)Comparator接口并重寫compare()方法。

(3).LinkedHashSet:鏈表形式的HashSet,僅在HashSet上添加了鏈表索引。因此此類集合有序(Linked)、查詢速度快(HashSet)。不過很少使用該集合類型。

HashSet集合

HashSet的用法沒什么可解釋的,方法都繼承自Set再繼承自Collection。需要說明的是它的無序性、不可重復(fù)性、計算hash值時的方法以及判斷重復(fù)性時的方法。

import java.util.*;

public class TestHashSet {

public static void main(String[] args) {

Set s = new HashSet();

s.add("abcd4");

s.add("abcd1");

s.add("abcd2");

s.add("abcd3");

s.add("abcd1"); //重復(fù)

for (Iterator it = s.iterator();it.hasNext();) {

Object obj = it.next();

System.out.println(obj);

}

}

}

得到的結(jié)果是無序且元素是不可重復(fù)的:

abcd2

abcd3

abcd4

abcd1

這里判斷字符串對象是否重復(fù)的方法是先調(diào)用String的hashcode()進行判斷,如果相同,再調(diào)用String的equals()方法。其中String的hashcode()方法在計算hash值時,是根據(jù)每個字符計算的,相同字符位置處的相同字符運算結(jié)果相同。

所以上面幾個字符串對象中,前綴"abcd"子串部分的hash運算結(jié)果相同,最后一個字符決定了這些字符串對象是否相同。插入時有兩個"abcd1",所以總共調(diào)用了一次String的equals()方法。

如果是存儲自定義的對象,如Student對象,該對象定義方式如下:

class Student {

String name;

int age;

Student(String name,int n) {

this.name = name;

this.age = n;

}

//override toString()

public String toString() {

return this.name + " " + this.age;

}

//override equals()

public boolean equals(Object obj) {

if (this == obj) {

return true;

}

if (!(obj instanceof Student)) {

return false;

}

Student stu = (Student)obj;

return this.name.equals(stu.name) && this.age == age;

}

}

即使重寫了equals(),插入屬性相同的Student對象到HashSet中時,也會認為不重復(fù)的。

import java.util.*;

public class TestHashSet {

public static void main(String[] args) {

Set s = new HashSet();

s.add(new Student("Malong1",21));

s.add(new Student("Malong1",21));

s.add(new Student("Malong1",21));

for (Iterator it = s.iterator();it.hasNext();) {

Object obj = it.next();

System.out.println(obj);

}

}

}

結(jié)果:

Malong1 21

Malong1 21

Malong1 21

這是因為HastSet集合的底層首先調(diào)用Student的hashcode()方法,而Student沒有重寫該方法,而是繼承自O(shè)bject,所以每個對象的hashcode()都不相同而直接插入到集合中。

因此,需要重寫Student的hashcode()方法。以下是一種重寫方法:

public int hashCode() {

return this.name.hashCode() + age*31; //31可以是任意數(shù),但不能是1或0。

}

如果不加上"age*31",那么name部分的hash值有可能是相同的,但這很可能不是同一Student對象,所以應(yīng)該加上age屬性作為計算hash值的一部分元素。但不能直接加age,因為這樣會導(dǎo)致"new Student("lisi3",23)"和"new Student("lisi2",24)"的hashcode相同(3+23=2+24),因此需要為age做一些修改,例如乘一個非0和1的整數(shù)。

在Student中重寫hashCode()后,再插入下面這些Student對象,就能相對精確地判斷是否為同一個Student元素。

s.add(new Student("lisi1",21));

s.add(new Student("lisi1",21)); //此處將調(diào)用equals(),且最終判斷為重復(fù)對象

s.add(new Student("lisi2",24));

s.add(new Student("lisi3",23)); //此處將調(diào)用equals()

s.add(new Student("Gaoxiao1",23));

s.add(new Student("Gaoxiao2",21));

s.add(new Student("Gaoxiao3",22));

結(jié)果:

lisi1 21

Gaoxiao1 23

Gaoxiao3 22

lisi2 24

lisi3 23

Gaoxiao2 21

LinkedHashSet集合

鏈表順序的HashSet集合,相比HashSet,只需多記錄一個鏈表索引即可,這就使得它保證了存儲順序和插入順序相同。實現(xiàn)方式除了new對象時和HashSet不一樣,其他任何地方都是一樣的。

import java.util.*;

public class TestHashSet {

public static void main(String[] args) {

Set s = new LinkedHashSet();

s.add(new Student("lisi1",21));

s.add(new Student("lisi1",21));

s.add(new Student("lisi2",24));

s.add(new Student("lisi3",23));

s.add(new Student("Gaoxiao1",23));

s.add(new Student("Gaoxiao3",21));

s.add(new Student("Gaoxiao2",22));

for (Iterator it = s.iterator();it.hasNext();) {

Object obj = it.next();

System.out.println(obj);

}

}

}

結(jié)果:

lisi1 21

lisi2 24

lisi3 23

Gaoxiao1 23

Gaoxiao3 21

Gaoxiao2 22

TreeSet集合

TreeSet集合以二叉樹數(shù)據(jù)結(jié)構(gòu)存儲元素。二叉樹保證了元素之間是排過序且相互唯一的,因此實現(xiàn)TreeSet集合最核心的地方在于對象之間的比較。

比較對象有兩種方式:一是在對象類中實現(xiàn)Comparable接口重寫compareTo()方法;二是定義一個專門用于對象比較的比較器,實現(xiàn)這個比較器的方法是實現(xiàn)Comparator接口并重寫compare()方法。其中Comparable接口提供的比較方法稱為自然順序,例如字母按照字典順序,數(shù)值按照數(shù)值大小順序。

無論是哪種方式,每個待插入的元素都需要先轉(zhuǎn)型為Comparable,確定了將要存儲在二叉樹上的節(jié)點位置后,然后再轉(zhuǎn)型為Object存儲到集合中。

插入String類對象。

由于String已經(jīng)重寫了compareTo(),因此下面插入String對象到TreeSet集合中沒有任何問題。

import java.util.*;

//

public class TestTreeSet {

public static void main(String[] args) {

Set t = new TreeSet();

t.add("abcd2");

t.add("abcd11");

t.add("abcd3");

t.add("abcd1");

//t.add(23);

//t.add(21);

//t.add(21);

for (Iterator it = t.iterator();it.hasNext();) {

Object obj = it.next();

System.out.println(obj);

}

}

}

但不能將上面"t.add(23)"等取消注釋,雖然Integer類也重寫了compareTo(),但在插入這些Integer類元素時,集合中已經(jīng)存在String類的元素,String類的compareTo()和Integer的compareTo()的比較方法不一樣,使得這兩類元素之間無法比較大小,也就無法決定數(shù)值類的元素插入到二叉樹的哪個節(jié)點。

插入實現(xiàn)了Comparable接口且重寫了compareTo()的自定義對象。

例如Student對象,如果沒有重寫compareTo()方法,將拋出異常,提示無法轉(zhuǎn)型為Comparable。

t.add(new Student("Malongshuai1",23));

結(jié)果:

Exception in thread "main" java.lang.ClassCastException: Student cannot be cast to java.lang.Comparable

at java.util.TreeMap.compare(Unknown Source)

at java.util.TreeMap.put(Unknown Source)

at java.util.TreeSet.add(Unknown Source)

at TestTreeSet.main(TestTreeSet.java:8)

所以,修改Student重寫compareTo(),在重寫應(yīng)該考慮哪個作為主排序?qū)傩?#xff0c;哪個作為次要排序?qū)傩浴@缫詎ame為主排序?qū)傩?#xff0c;age為次排序?qū)傩浴ompareTo()返回正數(shù)則表示大于,返回負數(shù)則表示小于,返回0則表示等于。如下:

class Student implements Comparable {

String name;

int age;

Student(String name,int n) {

this.name = name;

this.age = n;

}

public String toString() {

return this.name + " " + this.age;

}

public int compareTo(Object obj) {

if (!(obj instanceof Student)) {

throw new ClassCastException("Class cast wrong!");

}

Student stu = (Student)obj;

// compare name first, then age

int temp = this.name.compareTo(stu.name);

return temp == 0 ? this.age - stu.age :temp;

}

}

于是插入Student時,將根據(jù)name中的字母順序,相同時再根據(jù)age大小順序,最后如果都相同,則認為元素重復(fù),不應(yīng)該插入到集合中。

t.add(new Student("Malongshuai1",23));

t.add(new Student("Malongshuai3",21));

t.add(new Student("Malongshuai2",23));

t.add(new Student("Malongshuai1",23)); //重復(fù)

t.add(new Student("Malongshuai1",22));

結(jié)果:

Malongshuai1 22

Malongshuai1 23

Malongshuai2 23

Malongshuai3 21

使用比較器comparator實現(xiàn)排序。此時TreeSet的構(gòu)造方法為"TreeSet(Comparator comp)"。

當(dāng)使用了比較器后,插入數(shù)據(jù)時將默認使用比較器比較元素。

比較器是一個實現(xiàn)了java.util.Comparator接口并重寫了compare()方法的類,可以根據(jù)不同比較需求,創(chuàng)建不同的比較器。 例如創(chuàng)建一個根據(jù)age作為主排序?qū)傩?#xff0c;name作為次排序?qū)傩缘谋容^器SortByAge,由于這個比較器是用來比較Student對象大小的,因此必須先轉(zhuǎn)型為Student。

import java.util.*;

//

public class SortByAge implements Comparator {

public int compare(Object o1,Object o2) {

//Cast to Student first

if (!(o1 instanceof Student) || !(o2 instanceof Student)) {

throw new ClassCastException("Wrong");

}

Student s1 = (Student)o1;

Student s2 = (Student)o2;

//compare age first, then name

int temp = s1.age - s2.age;

return temp == 0 ? s1.name.compareTo(s2.name) : temp;

}

}

指定TreeSet的比較器為SortByAge,并插入一些Student對象:

public class TestTreeSet {

public static void main(String[] args) {

Set t = new TreeSet(new SortByAge());

t.add(new Student("Malongshuai1",23));

t.add(new Student("Malongshuai3",21));

t.add(new Student("Malongshuai2",23));

t.add(new Student("Malongshuai1",23)); //重復(fù)

t.add(new Student("Malongshuai1",22));

for (Iterator it = t.iterator();it.hasNext();) {

Object obj = it.next();

System.out.println(obj);

}

}

}

當(dāng)為TreeSet集合指定了比較器時,結(jié)果將先按照age順序再按照name排序的,盡管Student類中仍然重寫了compareTo()方法:

Malongshuai3 21

Malongshuai1 22

Malongshuai1 23

Malongshuai2 23

總結(jié)

以上就是本文關(guān)于集合框架(Collections Framework)詳解及代碼示例的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:

如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

總結(jié)

以上是生活随笔為你收集整理的java集合框架的结构_集合框架(Collections Framework)详解及代码示例的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

亚洲无人区小视频 | 91影视成人 | 玖玖综合网 | 综合网欧美 | 九草视频在线观看 | 国产精品日韩在线播放 | 精品久久久久免费极品大片 | 色福利网 | 伊人成人激情 | 人人揉人人揉人人揉人人揉97 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 欧美孕妇与黑人孕交 | 精品免费99久久 | 中文字幕91 | 成 人 免费 黄 色 视频 | 国产探花在线看 | 国产一区视频在线观看免费 | 日b视频国产 | 三级毛片视频 | 日韩欧美在线一区二区 | 国产人成一区二区三区影院 | 7777精品伊人久久久大香线蕉 | 亚洲黄色一级视频 | 96久久久| 久久一区二区三区国产精品 | 手机成人免费视频 | 免费日韩 精品中文字幕视频在线 | 欧美极品xxx | 精品国产一区二区三区久久久蜜月 | 国产直播av | 久久99精品国产一区二区三区 | 精品国产理论 | 久久草 | 国产美女免费 | 天天干天天干天天干天天干天天干天天干 | 久久精品欧美 | 欧美日本不卡高清 | 国产免费精彩视频 | 亚洲精品九九 | 中文字幕av全部资源www中文字幕在线观看 | 日韩精品一区二区在线 | 久艹在线免费观看 | 一本一本久久a久久 | 婷婷色在线播放 | 免费国产ww | 国产拍揄自揄精品视频麻豆 | 久久精彩免费视频 | 区一区二区三在线观看 | 四虎在线免费视频 | 亚州免费视频 | 久久99精品一区二区三区三区 | 国产精品久久一区二区无卡 | 最近日本mv字幕免费观看 | 日本不卡123区 | 亚洲免费国产视频 | 草久久av| 亚洲在线a | 黄色三级免费看 | 久久国产手机看片 | 久草综合视频 | 久久人人爽人人 | 人人人爽| 成人黄色视 | 韩国av不卡 | av免费看在线 | 99精品视频播放 | 亚洲精选99| 中文字幕在线观看完整版 | 97免费在线观看 | 成片人卡1卡2卡3手机免费看 | 日韩欧美v | 国产免费xvideos视频入口 | 国产香蕉在线 | 久久综合之合合综合久久 | 亚洲综合色av | 国产视频在 | 精品国产综合区久久久久久 | 久久精品日产第一区二区三区乱码 | 日韩视频一 | 最近更新好看的中文字幕 | 国产高清中文字幕 | 91在线视频观看免费 | 韩日电影在线 | 国产高清视频网 | 国产不卡在线 | 欧美国产三区 | 午夜在线免费视频 | 久久人人精 | 97色婷婷 | 国产免费专区 | 日韩在线免费观看视频 | 国产亚洲精品久久久久秋 | 亚洲区视频在线观看 | www.久久婷婷 | 九九日韩 | 中文字幕4 | 中文字幕一区二区三区四区视频 | 亚洲一片黄 | 一本一道波多野毛片中文在线 | 成人av电影免费观看 | 天天干,天天操,天天射 | 亚洲欧洲精品一区 | 青青网视频 | 国产超碰在线观看 | 亚洲精品国久久99热 | 丁香五婷 | 久久精品国产一区二区电影 | 国产精品久久久久久69 | 亚洲精品国产第一综合99久久 | 久久精品一区二区三区四区 | 免费黄a | 日本在线视频一区二区三区 | 欧美成年网站 | 亚洲黄色免费观看 | 波多野结衣久久资源 | 国产精品入口久久 | 久草在线观看视频免费 | 久久伊人八月婷婷综合激情 | 激情一区二区三区欧美 | 伊人色**天天综合婷婷 | 色www精品视频在线观看 | 91视频在线免费看 | 欧美a性| 天天操夜夜拍 | 免费在线日韩 | 网站免费黄 | 狠狠色丁香婷婷综合欧美 | 欧美夫妻性生活电影 | 最近中文字幕免费大全 | 国产精品普通话 | 在线观看成年人 | 中文av在线免费观看 | 欧美日韩国产在线观看 | 免费看黄的 | av电影一区二区三区 | 国产精华国产精品 | 国产精品久久久久久久久久妇女 | 午夜18视频在线观看 | 久久色视频 | 99re久久精品国产 | 日韩精品一区二区免费 | 精品国产欧美 | 91精品影视 | 欧美精品九九99久久 | 成年人视频在线观看免费 | 久久www免费人成看片高清 | 人人玩人人添人人澡97 | 久久综合久久综合久久综合 | av在线永久免费观看 | 国产美女搞久久 | 天天干,天天射,天天操,天天摸 | 久久免费a | 综合在线色 | 九九国产视频 | 操操操天天操 | 久久久久免费网 | 亚洲精品国产自产拍在线观看 | www.色午夜.com | 97成人在线视频 | 国产91精品久久久久久 | 国产精品嫩草影院99网站 | 日韩高清免费无专码区 | 国产成人一级 | 国产女做a爱免费视频 | 国产精品亚州 | 麻豆视频免费播放 | 精品久久久久久电影 | 狠狠地操 | 精品一区二区亚洲 | 亚洲天堂网在线视频观看 | 97在线免费观看视频 | 欧美日韩在线精品 | 免费久久99精品国产 | 2021国产视频| 天天操天天摸天天射 | 天天干天天操天天拍 | 三级黄色网络 | 日韩有码在线播放 | 一区二区三区精品在线 | 日韩高清在线一区二区 | 免费亚洲视频在线观看 | 亚洲精品中文在线 | 国产婷婷vvvv激情久 | 国精产品999国精产 久久久久 | 激情欧美在线观看 | 在线观看国产日韩欧美 | 丁香网婷婷 | 精品主播网红福利资源观看 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 亚洲视频中文 | 久久99久久99精品 | 国产精品综合久久 | 日韩天堂在线观看 | 中文字幕在线观看三区 | 日韩免费一区 | 99爱国产精品 | 国产精品一区二区三区在线看 | 日日夜夜网| 人人爽久久久噜噜噜电影 | 国产麻豆精品久久 | 中文字幕在线第一页 | 99精彩视频在线观看免费 | 日日干网址 | 丝袜美腿在线播放 | 91在线porny国产在线看 | 在线免费观看成人 | 中国一级特黄毛片大片久久 | 国产日韩欧美视频在线观看 | 999视频网站 | 激情综合色播五月 | 日韩免费在线观看视频 | 免费看的黄色的网站 | 91一区二区三区久久久久国产乱 | 国产成人精品免费在线观看 | 欧女人精69xxxxxx | 97视频免费在线观看 | 黄色av网站在线观看免费 | 欧美精品乱码久久久久久按摩 | 成人免费看片98欧美 | 免费特级黄毛片 | 久久在线观看视频 | 97在线资源| 91精品久久久久久久91蜜桃 | 日韩视频在线不卡 | 中文字幕免费在线看 | 中文字幕亚洲不卡 | 欧美精品三级在线观看 | 国产在线视频一区二区 | 日韩高清在线看 | 国产资源中文字幕 | 国产无遮挡又黄又爽在线观看 | av在线网站观看 | 一区二区三区动漫 | 免费在线观看av的网站 | 日日干av| 久久久久一区二区三区四区 | 亚洲精品成人av在线 | 激情开心站 | 久久视频免费 | 91成人免费看片 | 精一区二区| 久久久久久久久久久久av | 国产永久免费高清在线观看视频 | av免费网站在线观看 | 国产精品久久久久久久久久久久久久 | 色五月成人 | 亚洲一片黄| 黄色国产成人 | 国内成人精品视频 | 久久高清免费视频 | 国模精品在线 | 欧美日韩在线精品一区二区 | 成年人精品 | 五月婷婷激情综合 | 天天干天天干天天射 | 在线v片免费观看视频 | 国产成人精品免费在线观看 | 午夜精品成人一区二区三区 | 亚洲一区二区三区毛片 | 91麻豆免费看 | 亚洲欧洲一区二区在线观看 | 2022久久国产露脸精品国产 | 久久精品成人热国产成 | 成人av一区二区在线观看 | 久草视频免费观 | 久久久久久久久免费 | 在线直播av | 天天射综合网视频 | 久久都是精品 | 午夜久久福利视频 | av综合 日韩 | 日韩精品一区在线观看 | 日韩欧美一区二区在线观看 | 99精品99 | 国产一区二区久久精品 | 国产精品99久久免费观看 | 99精品一级欧美片免费播放 | 人人澡人人爽欧一区 | 91麻豆精品国产自产 | 免费a视频在线观看 | 超碰成人免费电影 | 亚洲人成免费 | 国产成人久久久77777 | 国产69久久精品成人看 | 看av免费| 天天操天天摸天天爽 | 三日本三级少妇三级99 | 中文字幕在线免费观看视频 | 国产精品一区二区三区免费看 | 精品夜夜嗨av一区二区三区 | 欧美成人tv | 中文字幕高清有码 | 97视频免费播放 | 日韩mv欧美mv国产精品 | 91精品国产高清自在线观看 | 亚洲精品一区二区久 | 婷婷午夜| 亚洲精品乱码久久久久久按摩 | 在线观看成人一级片 | 日韩精品中文字幕在线不卡尤物 | 国产精品黄色影片导航在线观看 | 超碰成人免费电影 | 奇米导航| 91成年人在线观看 | 日本久久电影网 | 91九色porn在线资源 | www久久九 | 久久综合欧美精品亚洲一区 | 国产高清视频网 | 久久免费精品视频 | 国产在线久草 | 成人sm另类专区 | 国产美女免费看 | 国产精品免费视频一区二区 | 免费看国产精品 | 久久午夜精品 | 国产一级视频在线免费观看 | 9999精品免费视频 | 2024国产精品视频 | 狠狠色狠狠色综合日日小说 | 国产一级片观看 | 黄色福利网| 丁香婷婷综合激情五月色 | 美女视频黄是免费的 | 亚洲一区免费在线 | 国产精品日韩高清 | 黄色在线视频网址 | 久久久久欠精品国产毛片国产毛生 | 免费观看一级特黄欧美大片 | 国产97视频 | 一区二区三区中文字幕在线 | 444av| 国产九九九视频 | 亚洲精品国产区 | 成人黄色毛片视频 | 免费视频一区二区 | 免费高清在线一区 | 亚洲影院一区 | 五月天天av| 1024手机在线看 | 亚洲九九影院 | 日韩国产欧美在线视频 | 国产精品不卡在线观看 | 右手影院亚洲欧美 | 手机在线看永久av片免费 | 亚洲午夜精品电影 | 人人搞人人爽 | 最新极品jizzhd欧美 | av福利网址导航 | 日韩天堂在线观看 | 国产亚洲精品电影 | 这里只有精品视频在线 | 99视频久久 | 国产在线成人 | 亚洲国产精品成人综合 | 精品少妇一区二区三区在线 | 天天干,狠狠干 | 久久国产精品99久久久久久老狼 | 色婷婷丁香 | 蜜桃麻豆www久久囤产精品 | 国产成人在线看 | 欧美日韩精品在线视频 | 成人小视频在线 | 99精品免费在线观看 | 日本激情中文字幕 | 久久看毛片 | 99热这里有 | 久久丁香 | 91九色成人 | 欧美一级视频免费看 | 久久av观看 | 国产精品2019 | 国产精品高清免费在线观看 | 国产精品一区二区电影 | 玖玖在线观看视频 | 日本精油按摩3 | 欧美日韩国产综合一区二区 | 精品国产不卡 | 国产又粗又猛又黄 | www.超碰| 国产麻豆成人传媒免费观看 | 天天在线操 | 日韩大片免费在线观看 | 国产亚洲精品久久久久久移动网络 | 国产一区二区高清视频 | 亚洲最新av在线网站 | 国产无套精品久久久久久 | 婷婷五天天在线视频 | 日韩免费视频观看 | 狠狠操天天操 | 中文字幕 国产视频 | 国产精品午夜av | 18国产精品福利片久久婷 | 天堂在线v | 亚洲国产资源 | 日韩在线观看你懂得 | 在线观看91精品视频 | 国产在线第三页 | 亚洲人人精品 | 毛片视频电影 | a视频在线播放 | 91久久黄色 | 亚洲免费色| 久久精品综合视频 | 欧美黑吊大战白妞欧美 | 中文字幕国产一区 | 久色小说 | 久热只有精品 | 超碰在线最新网址 | 亚洲精欧美一区二区精品 | 一区在线播放 | 亚洲电影黄色 | 免费在线观看av网址 | 日韩在线视频精品 | 亚洲人毛片 | 国产999精品 | 人人插人人射 | 国产最新在线视频 | 麻花传媒mv免费观看 | 久久久久在线观看 | 九九精品毛片 | 18做爰免费视频网站 | 国产精品美女久久久久久久 | 在线免费观看成人 | 久久精品国产一区二区 | 国产在线精品二区 | 免费观看成人av | 免费成人在线电影 | 黄色a视频免费 | 在线视频黄 | 免费在线观看的av网站 | 涩涩网站在线播放 | 天天插视频 | 亚洲精品视频免费在线 | 久久96| 国产手机av在线 | 亚洲精品福利在线 | 色综合久久久久久久 | 国产成人久久精品一区二区三区 | 国产另类av | 麻豆你懂的 | 婷婷5月色| 九九视频在线播放 | 免费网站看v片在线a | 国产一级黄 | 国产玖玖精品视频 | 久久国产精品久久国产精品 | 免费在线观看亚洲视频 | 欧美一区二区视频97 | 夜夜躁狠狠躁日日躁 | 中文字幕在线观看亚洲 | www.久久色 | 人人超碰免费 | 国产 日韩 欧美 自拍 | 国产专区一| 国产视频黄 | 久久爱资源网 | 成人9ⅰ免费影视网站 | 青春草免费在线视频 | 久久精品成人欧美大片古装 | 精品在线观看一区二区三区 | 国产精品18久久久久久不卡孕妇 | 婷婷激情五月综合 | 亚洲精品乱码久久久久久 | 中文资源在线播放 | 国产成人久久77777精品 | 国产婷婷精品av在线 | 久久99久久99 | 成人在线观看影院 | 国内精品久久天天躁人人爽 | 久草久视频| 人人爱人人做人人爽 | 国产精品久久久久久久久蜜臀 | 美国av片在线观看 | 免费在线观看亚洲视频 | 色噜噜在线观看 | 日韩日韩日韩日韩 | 欧美日韩在线观看一区二区 | 免费观看www7722午夜电影 | 奇米导航 | 国产不卡在线视频 | 麻豆久久一区二区 | 99热官网 | 欧美亚洲国产精品久久高清浪潮 | 处女av在线| 在线观看国产www | 最近中文字幕在线 | 国产精品欧美久久久久三级 | 91精品免费视频 | 成人一区电影 | 91av在线免费播放 | 日韩电影中文,亚洲精品乱码 | 国产一区二区网址 | 亚洲亚洲精品在线观看 | 一本一本久久a久久精品综合妖精 | 狠狠插狠狠干 | 91视视频在线直接观看在线看网页在线看 | 婷婷在线免费 | 欧洲亚洲精品 | 国产96在线 | 久久久久高清毛片一级 | 视频直播国产精品 | 韩国一区二区三区在线观看 | 亚洲国产一区在线观看 | 黄色av网站在线观看 | 欧美黄污视频 | 色九色| 久久99国产精品久久99 | 久久精品美女 | 亚洲一级片av | 欧美成人xxxx | 在线观看午夜 | 国产精品久久久久久久7电影 | 免费成人在线网站 | 在线视频中文字幕一区 | 一级成人在线 | 国产打女人屁股调教97 | 久久久国产精品麻豆 | 亚洲精品免费在线观看视频 | 欧美午夜精品久久久久久浪潮 | 精品国产一区二区三区久久久久久 | 麻豆91视频 | 欧美午夜精品久久久久久浪潮 | 成人在线观看影院 | 久久亚洲国产精品 | 午夜色场 | 欧美一区日韩精品 | 免费观看久久 | www好男人| 日本中文字幕网站 | 国产精品免费观看在线 | 九九精品视频在线观看 | 一区二区三区高清 | 国产女人18毛片水真多18精品 | 欧美aa一级 | 国产视频99 | 国产资源av | 欧美日韩国产二区 | 久久蜜桃av| 很黄很色很污的网站 | 九色最新网址 | 久久久久一区二区三区 | 国产精品女人久久久久久 | 国产99一区二区 | 国产成人久久精品一区二区三区 | 二区三区精品 | 久久av免费观看 | 91精品久久久久久综合五月天 | 国产一区高清在线观看 | 999久久国产精品免费观看网站 | 久久成人视屏 | 欧美精品久久久久久久亚洲调教 | 免费亚洲黄色 | 色综合五月天 | 亚洲 欧洲av | 免费久久片| 色综合久久久久久中文网 | 深爱激情五月网 | 最新av免费在线观看 | 最新av网址在线 | 国产91学生| 色吧久久| 久久情网 | 青春草视频在线播放 | 亚洲天天做 | 国产在线一卡 | 欧美专区日韩专区 | 在线观看亚洲a | 又大又硬又黄又爽视频在线观看 | 99热播精品 | 亚洲国产高清在线 | 97天天综合网 | 免费精品视频在线观看 | 精品国产伦一区二区三区观看体验 | 美女在线免费视频 | 激情五月婷婷网 | 亚洲一级性 | 免费看的黄网站软件 | 日日夜夜精品视频 | 91精品国产麻豆国产自产影视 | 成人免费91| 夜色资源网| 国产亚洲精品久久久久5区 成人h电影在线观看 | 精品国产亚洲在线 | 国产香蕉久久精品综合网 | 免费视频一二三 | 国产不卡在线观看视频 | 久久久久久视频 | 国产视频首页 | 99久久日韩精品视频免费在线观看 | 精品视频久久久久久 | av免费看网站 | 欧美日韩免费观看一区=区三区 | 天天色天天操天天爽 | 亚洲va天堂va欧美ⅴa在线 | 91视频成人免费 | 成人免费在线观看入口 | 亚洲影院国产 | 激情综合五月婷婷 | 亚洲黄a| 成年人在线观看免费视频 | 99精品美女 | 中文在线亚洲 | 97视频免费在线 | 免费观看9x视频网站在线观看 | 9999毛片| 精品二区视频 | 91禁看片 | 国产一区在线视频播放 | 欧美999| 五月婷婷丁香色 | 成人免费亚洲 | 欧美亚洲精品在线观看 | 色噜噜狠狠色综合中国 | 婷婷综合亚洲 | 国产精品不卡av | 国产精品视频大全 | 97超碰资源| 国产精品久久精品 | 蜜臀一区二区三区精品免费视频 | 国产精品视频免费在线观看 | 99热在线观看免费 | 亚洲午夜久久久久久久久电影网 | 特片网久久 | 成人黄色片免费看 | 日本爱爱免费视频 | 欧美成人xxxx | 一本一本久久aa综合精品 | 黄色av网站在线观看免费 | 中文字幕av播放 | 精品视频国产 | 99亚洲精品在线 | 欧美久草视频 | 欧美国产高清 | 国产不卡视频在线播放 | 91九色视频国产 | 操操操干干干 | 视频二区在线视频 | 久久久午夜精品理论片中文字幕 | 成年人免费av | 91香蕉国产在线观看软件 | 天天色天天干天天色 | 夜夜躁日日躁狠狠久久88av | 又色又爽又激情的59视频 | 日韩三级视频在线看 | 欧美成人h版在线观看 | av中文字幕在线免费观看 | 久草免费在线观看 | 999国内精品永久免费视频 | 天堂在线视频中文网 | 日日天天狠狠 | 丁香视频在线观看 | 亚洲区另类春色综合小说校园片 | 日韩高清 一区 | 天天干,夜夜爽 | 国产日韩精品一区二区三区 | 日韩电影黄色 | 日韩专区一区二区 | 91免费网址 | 国产精品电影一区二区 | 992tv又爽又黄的免费视频 | 亚洲精品国产精品国自产观看浪潮 | 日韩久久激情 | 人人讲下载 | av高清一区二区三区 | 91av免费看| 国产成人精品亚洲精品 | 涩涩爱夜夜爱 | 国产香蕉视频在线观看 | 国色天香第二季 | 亚洲码国产日韩欧美高潮在线播放 | 久久欧美综合 | 国产成人久久精品亚洲 | 黄色成人在线网站 | 日韩欧美电影网 | 成年人黄色免费看 | 国产91综合一区在线观看 | 亚洲人人网 | 欧美二区视频 | 涩五月婷婷 | 少妇性aaaaaaaaa视频 | 国产精品18毛片一区二区 | 色是在线视频 | 亚洲国产精品成人综合 | 97天天综合网 | 久久免费电影网 | 五月婷婷激情综合网 | 亚洲精品一区二区精华 | 国产精品18videosex性欧美 | 黄色软件在线观看视频 | 久久香蕉影视 | 久久综合精品国产一区二区三区 | 99色在线视频 | 九九精品毛片 | www日韩高清| www.夜夜爱| 黄色免费网 | 欧美美女一级片 | 成年人在线观看网站 | 日韩欧美一区二区三区免费观看 | 欧美最猛性xxxx | 伊人午夜 | 婷婷六月丁 | 97精品国产一二三产区 | 国产精品9999久久久久仙踪林 | 特级免费毛片 | 久久精品永久免费 | 97在线精品视频 | 99色免费视频 | 91亚色免费视频 | 免费看一级片 | 91丨九色丨蝌蚪丨老版 | 久久在线观看视频 | 欧美 日韩 性 | 中文在线√天堂 | 免费观看av网站 | 日韩精品久久久久久久电影竹菊 | 亚洲精品自在在线观看 | 激情电影在线观看 | 欧美精品一二 | 亚洲va男人天堂 | 国产高清中文字幕 | 香蕉视频在线免费 | 日韩电影在线看 | 日日草天天草 | 日本99干网 | 久久久精品久久日韩一区综合 | 国产日韩精品在线观看 | 亚洲成人免费在线 | a久久免费视频 | 欧美黑人xxxx猛性大交 | 最近乱久中文字幕 | 一级淫片a| 精品国产一区二区三区久久久久久 | 国产免费大片 | 亚洲精品影院在线观看 | 亚洲黄在线观看 | 日本久久中文 | 九九久久久久久久久激情 | 国产黄大片在线观看 | 婷婷网站天天婷婷网站 | 久久国产精品小视频 | 欧美日韩国产一区二区三区 | 亚洲精品99 | 一二三久久久 | www久久久久 | 日韩视频一二三区 | 久热免费在线观看 | 免费又黄又爽视频 | 国产中文在线播放 | 5月丁香婷婷综合 | 在线观看日韩av | 久久草网 | 亚洲精品欧洲精品 | 久久久久久蜜av免费网站 | 亚洲色图美腿丝袜 | 精品综合久久久 | 少妇性aaaaaaaaa视频 | 毛片网站免费 | 久久福利 | 久久国产精品二国产精品中国洋人 | av亚洲产国偷v产偷v自拍小说 | 久久视频免费在线 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 国产成人一区二区三区久久精品 | 国产精品美女久久久久久久 | 日韩欧美精品在线观看 | 亚洲91视频| 久久爱www. | 91视频免费视频 | 久久久福利视频 | 99精品国产福利在线观看免费 | 精品在线亚洲视频 | 色视频国产直接看 | 在线观看日韩一区 | 中文字幕第一页在线 | 欧美视频www | 亚洲国内精品在线 | 亚洲成人资源在线 | 亚洲五月综合 | 国精产品999国精产 久久久久 | 欧洲性视频| 精品在线观看免费 | 久久久久国产精品厨房 | 国产一区在线不卡 | 欧美性极品xxxx做受 | 国产日韩精品在线 | 国产欧美精品在线观看 | 欧美成人按摩 | 亚洲专区免费观看 | 99久久99久久精品免费 | 欧美精品久久久久久久免费 | 日韩三级在线 | 91网址在线 | 精品国产1区二区 | av怡红院 | 中文字幕一区二区三区乱码不卡 | 国产精品日韩欧美一区二区 | 国产亚洲精品中文字幕 | 国产成人一区二区三区电影 | 亚洲国产免费看 | 日韩中文三级 | 久久狠狠干 | 992tv又爽又黄的免费视频 | 久久精品看 | 免费观看成人网 | 国产女人40精品一区毛片视频 | 久草视频中文在线 | 亚洲日本va在线观看 | 久久91网 | 天天草网站| 久久a免费视频 | 精品久久久久一区二区国产 | 日韩区欧美久久久无人区 | 色五月激情五月 | 国产一级黄色电影 | 日韩在线播放视频 | 久久av不卡| 久一久久 | 亚洲一区不卡视频 | 丁香视频在线观看 | 婷婷色网站 | 中文字幕精品久久 | av一级片在线观看 | 中文字幕视频一区二区 | 中文字幕一区二区三区四区在线视频 | 久久只精品99品免费久23小说 | 久草在线视频在线观看 | 99精品视频免费在线观看 | 色综合天天综合 | 欧美日产在线观看 | 嫩草av影院 | 激情综合五月婷婷 | 在线中文字母电影观看 | 在线 高清 中文字幕 | 国产电影一区二区三区四区 | 国产伦精品一区二区三区在线 | 日本精品在线看 | 欧美成人精品在线 | 精品99在线观看 | 九九精品毛片 | 日本三级国产 | 久草在线视频中文 | 成人av免费在线观看 | 国产精品v欧美精品 | 免费在线观看av片 | 国产99一区二区 | 香蕉视频在线观看免费 | 亚洲高清av| 久久狠狠干 | 欧美激情精品久久久久久 | 成人av高清在线观看 | 夜夜躁天天躁很躁波 | 日本3级在线观看 | 国产麻豆精品传媒av国产下载 | 91精品啪在线观看国产线免费 | 国产黄| 精品久久久99 | 97电影在线 | 日韩高清一二区 | 丁香花在线观看免费完整版视频 | 三级av小说 | 99精品视频一区二区 | 狠狠操狠狠干2017 | 国产免费黄视频在线观看 | 免费在线国产黄色 | 最新av中文字幕 | 99免费看片 | 人人狠狠综合久久亚洲婷 | www.五月天激情 | 天天av在线播放 | 久久视频免费 | 亚洲免费在线看 | 黄网站免费久久 | 波多野结衣视频网址 | 亚洲成av片人久久久 | 91香蕉亚洲精品 | 日本精品久久久久 | 日韩免费av片 | 91av免费看 | 久久久99精品免费观看乱色 | 久久国产香蕉视频 | 午夜丁香网 | 日日爽视频 | 亚洲涩综合 | 国产精品久久影院 | 天天综合天天做天天综合 | a视频免费在线观看 | 狠狠干在线播放 | 欧美天堂久久 | 91高清不卡 | 欧美一区二区日韩一区二区 | 九九热在线观看视频 | 九九综合在线 | 日韩亚洲在线观看 | 在线91色| 亚洲精品一区二区网址 | 中文字幕乱视频 | 丁香综合av | av电影在线播放 | 欧美日韩高清在线一区 | 国产成人精品一区二区三区福利 | 中文字幕视频网站 | 国产精品va视频 | 日韩欧美不卡 | 亚洲国产精品日韩 | 四虎视频 | 久草在线最新 | 国产色在线观看 | 草免费视频 | 欧美日韩高清在线一区 | 日韩一区二区三区免费视频 | 国产精品久久久久久久久搜平片 | 亚洲天堂在线观看完整版 | 精品人人人人 | 4438全国亚洲精品观看视频 | 欧美成人tv| 色吧av色av | 国产小视频你懂的 | 色婷婷激情四射 | 特级毛片在线免费观看 | 丁香久久综合 | 91精品爽啪蜜夜国产在线播放 | 日韩国产欧美在线视频 | 国产精品99久久久精品 | 精品欧美小视频在线观看 | 特级毛片爽www免费版 | 久草在线免费播放 | 国产精品一区二区三区久久 | 麻豆国产在线视频 | 日韩中文在线观看 | 久久激情电影 | 亚洲成人动漫在线观看 | 久草影视在线 | a在线观看免费视频 | 国产黄色免费电影 | 日韩久久久久久久久 | 久久伦理影院 | 国产裸体视频bbbbb | 精品黄色在线观看 | 亚洲精品99 | 国产操在线 | 亚洲第一av在线播放 | 国产69精品久久久久久久久久 | 99资源网| 国产精品久久久久久爽爽爽 | 99国产精品免费网站 | 麻豆传媒在线视频 | 九九影视理伦片 | 天堂av在线 | 亚洲一级片在线看 | 日韩在线视频观看 | 婷婷伊人五月 | 久久av免费观看 | 国产 字幕 制服 中文 在线 | 国产黄色精品在线 | 99久久精品日本一区二区免费 | 91自拍视频在线观看 | 免费视频一级片 | 国产在线美女 | 亚洲欧美日韩一二三区 | 国产 视频 高清 免费 | 手机av在线不卡 | 五月婷婷播播 | 亚洲免费在线播放视频 | 日韩影视在线观看 | 国产精品麻豆一区二区三区 | 996久久国产精品线观看 | 国语精品久久 | 免费视频91 | 亚欧洲精品视频在线观看 | 香蕉免费| 在线观看av黄色 | 人人搞人人干 | 51久久夜色精品国产麻豆 | 91污污| 国内精品久久久久 | 日韩免费电影在线观看 | 精品亚洲国产视频 | 韩国av一区二区三区在线观看 | 久久久一本精品99久久精品66 | 国产剧情亚洲 | 欧美大香线蕉线伊人久久 | 国产中的精品av小宝探花 | 久久成人国产精品免费软件 | 久久玖| 日本中文字幕在线视频 | 免费观看的av网站 | 久久精品韩国 | 久久伦理 | 视频在线日韩 | 五月开心网| 99热99re6国产在线播放 | 日韩av影视| 国产精品九九视频 | 伊人天天 | 黄色一区二区在线观看 | 最近更新好看的中文字幕 |