精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

動(dòng)圖圖解GC算法-讓垃圾回收動(dòng)起來(lái)!

開(kāi)發(fā) 前端 算法
本文中,我們先介紹了垃圾收集的基本問(wèn)題,什么樣的對(duì)象可以作為垃圾被回收?jvm中通過(guò)可達(dá)性分析算法解決了這一關(guān)鍵問(wèn)題,并在它的基礎(chǔ)上衍生出了多種常用的垃圾收集算法,不同算法具有各自的優(yōu)缺點(diǎn),根據(jù)其特點(diǎn)被應(yīng)用于各個(gè)年代。

[[425799]]

提到Java中的垃圾回收,我相信很多小伙伴和我一樣,第一反應(yīng)就是面試必問(wèn)了,你要是沒(méi)背過(guò)點(diǎn)GC算法、收集器什么的知識(shí),出門都不敢說(shuō)自己背過(guò)八股文。說(shuō)起來(lái)還真是有點(diǎn)尷尬,工作中實(shí)際用到這方面知識(shí)的場(chǎng)景真是不多,并且這東西學(xué)起來(lái)也很枯燥,但是奈何面試官就是愛(ài)問(wèn),我們能有什么辦法呢?

既然已經(jīng)卷成了這樣,不學(xué)也沒(méi)有辦法,Hydra犧牲了周末時(shí)間,給大家畫了幾張動(dòng)圖,希望通過(guò)這幾張圖,能夠幫助大家對(duì)垃圾收集算法有個(gè)更好的理解。廢話不多說(shuō),首先還是從基礎(chǔ)問(wèn)題開(kāi)始,看看怎么判斷一個(gè)對(duì)象是否應(yīng)該被回收。

判斷對(duì)象存活

垃圾回收的根本目的是利用一些算法進(jìn)行內(nèi)存的管理,從而有效的利用內(nèi)存空間,在進(jìn)行垃圾回收前,需要判斷對(duì)象的存活情況,在jvm中有兩種判斷對(duì)象的存活算法,下面分別進(jìn)行介紹。

1、引用計(jì)數(shù)算法

在對(duì)象中添加一個(gè)引用計(jì)數(shù)器,每當(dāng)有一個(gè)地方引用它時(shí)計(jì)數(shù)器就加 1,當(dāng)引用失效時(shí)計(jì)數(shù)器減 1。當(dāng)計(jì)數(shù)器為0的時(shí)候,表示當(dāng)前對(duì)象可以被回收。

這種方法的原理很簡(jiǎn)單,判斷起來(lái)也很高效,但是存在兩個(gè)問(wèn)題:

  • 堆中對(duì)象每一次被引用和引用清除時(shí),都需要進(jìn)行計(jì)數(shù)器的加減法操作,會(huì)帶來(lái)性能損耗
  • 當(dāng)兩個(gè)對(duì)象相互引用時(shí),計(jì)數(shù)器永遠(yuǎn)不會(huì)0。也就是說(shuō),即使這兩個(gè)對(duì)象不再被程序使用,仍然沒(méi)有辦法被回收,通過(guò)下面的例子看一下循環(huán)引用時(shí)的計(jì)數(shù)問(wèn)題:
  1. public void reference(){ 
  2.   A a = new A(); 
  3.   B b = new B(); 
  4.   a.instance = b; 
  5.   b.instance = a;     

引用計(jì)數(shù)的變化過(guò)程如下圖所示:

可以看到,在方法執(zhí)行完成后,棧中的引用被釋放,但是留下了兩個(gè)對(duì)象在堆內(nèi)存中循環(huán)引用,導(dǎo)致了兩個(gè)實(shí)例最后的引用計(jì)數(shù)都不為0,最終這兩個(gè)對(duì)象的內(nèi)存將一直得不到釋放,也正是因?yàn)檫@一缺陷,使引用計(jì)數(shù)算法并沒(méi)有被實(shí)際應(yīng)用在gc過(guò)程中。

2、可達(dá)性分析算法

可達(dá)性分析算法是jvm默認(rèn)使用的尋找垃圾的算法,需要注意的是,雖然說(shuō)的是尋找垃圾,但實(shí)際上可達(dá)性分析算法尋找的是仍然存活的對(duì)象。至于這樣設(shè)計(jì)的理由,是因?yàn)槿绻苯訉ふ覜](méi)有被引用的垃圾對(duì)象,實(shí)現(xiàn)起來(lái)相對(duì)復(fù)雜、耗時(shí)也會(huì)比較長(zhǎng),反過(guò)來(lái)標(biāo)記存活的對(duì)象會(huì)更加省時(shí)。

可達(dá)性分析算法的基本思路就是,以一系列被稱為GC Roots的對(duì)象作為起始點(diǎn),從這些節(jié)點(diǎn)開(kāi)始向下搜索,搜索所走過(guò)的路徑稱為引用鏈,當(dāng)一個(gè)對(duì)象到GC Roots沒(méi)有任何引用鏈相連時(shí),證明該對(duì)象不再存活,可以作為垃圾被回收。

在java中,可作為GC Roots的對(duì)象有以下幾種:

  • 在虛擬機(jī)棧(棧幀的本地變量表)中引用的對(duì)象
  • 在方法區(qū)中靜態(tài)屬性引用的對(duì)象
  • 在方法區(qū)中常量引用的對(duì)象
  • 在本地方法棧中JNI(native方法)引用的對(duì)象
  • jvm內(nèi)部的引用,如基本數(shù)據(jù)類型對(duì)應(yīng)的Class對(duì)象、一些常駐異常對(duì)象等,及系統(tǒng)類加載器
  • 被同步鎖synchronized持有的對(duì)象引用
  • 反映jvm內(nèi)部情況的 JMXBean、JVMTI中注冊(cè)的回調(diào)本地代碼緩存等
  • 此外還有一些臨時(shí)性的GC Roots,這是因?yàn)槔占蠖嗖捎梅执占途植炕厥眨紤]到跨代或跨區(qū)域引用的對(duì)象時(shí),就需要將這部分關(guān)聯(lián)的對(duì)象也添加到GC Roots中以確保準(zhǔn)確性

其中比較重要、同時(shí)提到的比較多的還是前面4種,其他的簡(jiǎn)單了解一下即可。在了解了jvm是如何尋找垃圾對(duì)象之后,我們來(lái)看一看不同的垃圾收集算法的執(zhí)行過(guò)程是怎樣的。

垃圾收集算法

1、標(biāo)記-清除算法

標(biāo)記清除算法是一種非常基礎(chǔ)的垃圾收集算法,當(dāng)堆中的有效內(nèi)存空間耗盡時(shí),會(huì)觸發(fā)STW(stop the world),然后分標(biāo)記和清除兩階段來(lái)進(jìn)行垃圾收集工作:

  • 標(biāo)記:從GC Roots的節(jié)點(diǎn)開(kāi)始進(jìn)行掃描,對(duì)所有存活的對(duì)象進(jìn)行標(biāo)記,將其記錄為可達(dá)對(duì)象
  • 清除:對(duì)整個(gè)堆內(nèi)存空間進(jìn)行掃描,如果發(fā)現(xiàn)某個(gè)對(duì)象未被標(biāo)記為可達(dá)對(duì)象,那么將其回收

通過(guò)下面的圖,簡(jiǎn)單的看一下兩階段的執(zhí)行過(guò)程:

但是這種算法會(huì)帶來(lái)幾個(gè)問(wèn)題:

  • 在進(jìn)行GC時(shí)會(huì)產(chǎn)生STW,停止整個(gè)應(yīng)用程序,造成用戶體驗(yàn)較差
  • 標(biāo)記和清除兩個(gè)階段的效率都比較低,標(biāo)記階段需要從根集合進(jìn)行掃描,清除階段需要對(duì)堆內(nèi)所有的對(duì)象進(jìn)行遍歷
  • 僅對(duì)非存活的對(duì)象進(jìn)行處理,清除之后會(huì)產(chǎn)生大量不連續(xù)的內(nèi)存碎片。導(dǎo)致之后程序在運(yùn)行時(shí)需要分配較大的對(duì)象時(shí),無(wú)法找到足夠的連續(xù)內(nèi)存,會(huì)再觸發(fā)一次新的垃圾收集動(dòng)作

此外,jvm并不是真正的把垃圾對(duì)象進(jìn)行了遍歷,把內(nèi)部的數(shù)據(jù)都刪除了,而是把垃圾對(duì)象的首地址和尾地址進(jìn)行了保存,等到再次分配內(nèi)存時(shí),直接去地址列表中分配,通過(guò)這一措施提高了一些標(biāo)記清除算法的效率。

2、復(fù)制算法

復(fù)制算法主要被應(yīng)用于新生代,它將內(nèi)存分為大小相同的兩塊,每次只使用其中的一塊。在任意時(shí)間點(diǎn),所有動(dòng)態(tài)分配的對(duì)象都只能分配在其中一個(gè)內(nèi)存空間,而另外一個(gè)內(nèi)存空間則是空閑的。復(fù)制算法可以分為兩步:

  • 當(dāng)其中一塊內(nèi)存的有效內(nèi)存空間耗盡后,jvm會(huì)停止應(yīng)用程序運(yùn)行,開(kāi)啟復(fù)制算法的gc線程,將還存活的對(duì)象復(fù)制到另一塊空閑的內(nèi)存空間。復(fù)制后的對(duì)象會(huì)嚴(yán)格按照內(nèi)存地址依次排列,同時(shí)gc線程會(huì)更新存活對(duì)象的內(nèi)存引用地址,指向新的內(nèi)存地址
  • 在復(fù)制完成后,再把使用過(guò)的空間一次性清理掉,這樣就完成了使用的內(nèi)存空間和空閑內(nèi)存空間的對(duì)調(diào),使每次的內(nèi)存回收都是對(duì)內(nèi)存空間的一半進(jìn)行回收

通過(guò)下面的圖來(lái)看一下復(fù)制算法的執(zhí)行過(guò)程:

復(fù)制算法的的優(yōu)點(diǎn)是彌補(bǔ)了標(biāo)記清除算法中,會(huì)出現(xiàn)內(nèi)存碎片的缺點(diǎn),但是它也同樣存在一些問(wèn)題:

只使用了一半的內(nèi)存,所以內(nèi)存的利用率較低,造成了浪費(fèi)

如果對(duì)象的存活率很高,那么需要將很多對(duì)象復(fù)制一遍,并且更新它們的應(yīng)用地址,這一過(guò)程花費(fèi)的時(shí)間會(huì)非常的長(zhǎng)

從上面的缺點(diǎn)可以看出,如果需要使用復(fù)制算法,那么有一個(gè)前提就是要求對(duì)象的存活率要比較低才可以,因此,復(fù)制算法更多的被用于對(duì)象“朝生暮死”發(fā)生更多的新生代中。

3、標(biāo)記-整理算法

標(biāo)記整理算法和標(biāo)記清除算法非常的類似,主要被應(yīng)用于老年代中。可分為以下兩步:

標(biāo)記:和標(biāo)記清除算法一樣,先進(jìn)行對(duì)象的標(biāo)記,通過(guò)GC Roots節(jié)點(diǎn)掃描存活對(duì)象進(jìn)行標(biāo)記

整理:將所有存活對(duì)象往一端空閑空間移動(dòng),按照內(nèi)存地址依次排序,并更新對(duì)應(yīng)引用的指針,然后清理末端內(nèi)存地址以外的全部?jī)?nèi)存空間

標(biāo)記整理算法的執(zhí)行過(guò)程如下圖所示:

可以看到,標(biāo)記整理算法對(duì)前面的兩種算法進(jìn)行了改進(jìn),一定程度上彌補(bǔ)了它們的缺點(diǎn):

  • 相對(duì)于標(biāo)記清除算法,彌補(bǔ)了出現(xiàn)內(nèi)存空間碎片的缺點(diǎn)
  • 相對(duì)于復(fù)制算法,彌補(bǔ)了浪費(fèi)一半內(nèi)存空間的缺點(diǎn)

但是同樣,標(biāo)記整理算法也有它的缺點(diǎn),一方面它要標(biāo)記所有存活對(duì)象,另一方面還添加了對(duì)象的移動(dòng)操作以及更新引用地址的操作,因此標(biāo)記整理算法具有更高的使用成本。

4、分代收集算法

實(shí)際上,java中的垃圾回收器并不是只使用的一種垃圾收集算法,當(dāng)前大多采用的都是分代收集算法。jvm一般根據(jù)對(duì)象存活周期的不同,將內(nèi)存分為幾塊,一般是把堆內(nèi)存分為新生代和老年代,再根據(jù)各個(gè)年代的特點(diǎn)選擇最佳的垃圾收集算法。主要思想如下:

新生代中,每次收集都會(huì)有大量對(duì)象死去,所以可以選擇復(fù)制算法,只需要復(fù)制少量對(duì)象以及更改引用,就可以完成垃圾收集

老年代中,對(duì)象存活率比較高,使用復(fù)制算法不能很好的提高性能和效率。另外,沒(méi)有額外的空間對(duì)它進(jìn)行分配擔(dān)保,因此選擇標(biāo)記清除或標(biāo)記整理算法進(jìn)行垃圾收集

通過(guò)圖來(lái)簡(jiǎn)單看一下各種算法的主要應(yīng)用區(qū)域:

至于為什么在某一區(qū)域選擇某種算法,還是和三種算法的特點(diǎn)息息相關(guān)的,再?gòu)?個(gè)維度進(jìn)行一下對(duì)比:

  • 執(zhí)行效率:從算法的時(shí)間復(fù)雜度來(lái)看,復(fù)制算法最優(yōu),標(biāo)記清除次之,標(biāo)記整理最低
  • 內(nèi)存利用率:標(biāo)記整理算法和標(biāo)記清除算法較高,復(fù)制算法最差
  • 內(nèi)存整齊程度:復(fù)制算法和標(biāo)記整理算法較整齊,標(biāo)記清除算法最差

盡管具有很多差異,但是除了都需要進(jìn)行標(biāo)記外,還有一個(gè)相同點(diǎn),就是在gc線程開(kāi)始工作時(shí),都需要STW暫停所有工作線程。

總結(jié)

本文中,我們先介紹了垃圾收集的基本問(wèn)題,什么樣的對(duì)象可以作為垃圾被回收?jvm中通過(guò)可達(dá)性分析算法解決了這一關(guān)鍵問(wèn)題,并在它的基礎(chǔ)上衍生出了多種常用的垃圾收集算法,不同算法具有各自的優(yōu)缺點(diǎn),根據(jù)其特點(diǎn)被應(yīng)用于各個(gè)年代。

雖然這篇文章嘮嘮叨叨了這么多,不過(guò)這些都還是基礎(chǔ)的知識(shí),如果想要徹底的掌握jvm中的垃圾收集,后續(xù)還有垃圾收集器、內(nèi)存分配等很多的知識(shí)需要理解,不過(guò)我們今天就介紹到這里啦,希望通過(guò)這一篇圖解,能夠幫助大家更好的理解垃圾收集算法。

本文轉(zhuǎn)載自微信公眾號(hào)「碼農(nóng)參上」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系碼農(nóng)參上公眾號(hào)。

 

責(zé)任編輯:武曉燕 來(lái)源: 碼農(nóng)參上
相關(guān)推薦

2011-09-15 17:36:29

Android應(yīng)用Call Cartoo動(dòng)畫

2022-06-07 09:00:32

PythonAI靜態(tài)圖片

2009-06-19 11:18:51

Factory BeaSpring配置

2020-11-16 11:50:21

Python代碼命令

2013-05-27 15:35:18

用友UAP移動(dòng)應(yīng)用移動(dòng)平臺(tái)

2011-06-01 14:51:54

jQuery

2012-09-03 09:21:51

2010-09-08 09:48:56

Gif播放教程Android

2018-07-26 13:53:27

2010-05-21 11:03:51

統(tǒng)一通信系統(tǒng)

2021-04-12 11:47:21

人工智能知識(shí)圖譜

2024-03-28 13:14:00

數(shù)據(jù)訓(xùn)練

2014-03-21 09:52:29

jQuery動(dòng)畫插件

2012-05-21 10:53:30

HTML5

2022-07-13 15:46:57

Python數(shù)據(jù)可視化代碼片段

2015-12-01 13:51:52

Webrtc

2022-02-24 08:30:24

操作系統(tǒng)CPU程序

2022-01-25 09:15:39

V8垃圾回收算法

2010-09-01 17:35:41

云計(jì)算

2022-10-08 18:25:22

Python內(nèi)存管理GC
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

久久久久久少妇| 91成人在线观看喷潮教学| 欧美brazzers| 色999日韩| 欧美三级一区二区| 亚洲人成网站在线播放2019| 91精品视频免费在线观看 | 国产aⅴ精品一区二区三区黄| 五月天婷婷网站| 欧美精品一二| 日韩一级二级三级精品视频| 欧美 日韩 激情| 日本视频在线观看| 国产成人一级电影| 日本精品一区二区三区在线| 成人在线观看高清| 欧美男男freegayvideosroom| 91国产成人在线| 日本高清视频免费在线观看| 黄色在线视频观看网站| 国产一区二区伦理| 日本免费一区二区三区视频观看| 五月天激情丁香| 国产传媒欧美日韩成人精品大片| 日韩一级大片在线观看| 在线观看av网页| 成人三级高清视频在线看| 欧美国产精品v| 久久99国产精品| 国产农村妇女毛片精品| 久久男女视频| 性欧美亚洲xxxx乳在线观看| 永久av免费网站| 国产成人精品999在线观看| 欧美成人video| 中文字幕国内自拍| 亚洲欧美韩国| 激情懂色av一区av二区av| 中文字幕一区二区三区最新| 国产永久免费高清在线观看视频| eeuss国产一区二区三区 | 亚洲欧美精品一区二区三区| 欧美三级黄美女| 色噜噜狠狠色综合网图区 | 国产毛片一区二区三区va在线| 亚洲中字黄色| 8x海外华人永久免费日韩内陆视频 | 国产情侣免费视频| 久久成人一区| 26uuu日韩精品一区二区| 国产一级特黄a高潮片| 中出一区二区| 欧美成人免费一级人片100| 欧美aaa级片| 日韩欧美一区免费| 一区二区亚洲欧洲国产日韩| 国产成人av一区二区三区不卡| 欧美激情极品| 亚洲精品美女在线| 影音先锋人妻啪啪av资源网站| 无码国模国产在线观看| 欧美一区二区播放| 国产男女无遮挡猛进猛出| www.久久久.com| 91精品国产综合久久香蕉的特点 | 中文字幕乱码中文乱码51精品| 亚洲成人激情av| 男人日女人视频网站| 69av成人| 欧美性极品xxxx娇小| 男人操女人免费软件| 成人在线爆射| 欧美日韩aaa| 欧美69精品久久久久久不卡| 国产精品超碰| 亚洲男人7777| av在线播放中文字幕| 亚洲精品2区| 色综合色综合久久综合频道88| 国产精久久久久久| 国产偷自视频区视频一区二区| 人九九综合九九宗合| 青青艹在线观看| 国产一区二区视频在线播放| 国产精品久久久对白| 深夜影院在线观看| 国产片一区二区| 精品一区二区成人免费视频 | 日本91av在线播放| 这里只有久久精品视频| 精品中文av资源站在线观看| 不卡视频一区二区三区| 四虎国产精品永远| 国产精品久久久久9999吃药| 91国在线高清视频| 三级在线观看视频| 6080午夜不卡| 久久人妻少妇嫩草av无码专区| 国产99亚洲| 久久中文字幕在线视频| 尤物视频在线观看国产| 麻豆精品一区二区综合av| ts人妖另类在线| 毛片网站在线观看| 成人免费一区二区三区在线观看| 免费超爽大片黄| 四虎4545www国产精品| 日韩精品一区二区三区在线观看 | 亚洲欧美一区二区在线观看| 青青青在线视频播放| 成人在线视频播放| 精品99999| 国产福利在线导航| 亚洲精品孕妇| 亚洲aⅴ日韩av电影在线观看| 亚洲色偷精品一区二区三区| 亚洲免费色视频| 麻豆av免费在线| 99久久香蕉| 日日噜噜噜夜夜爽亚洲精品| 三级黄色在线视频| 国产美女av一区二区三区| 噜噜噜噜噜久久久久久91| 18视频在线观看| 欧美性做爰猛烈叫床潮| 完美搭档在线观看| 一区二区三区在线| 国产精品久久久久久久久久久久久久 | 亚洲黄色在线| 91手机在线视频| 日本最新在线视频| 在线亚洲高清视频| 不卡一区二区在线观看| 欧美激情综合| 91超碰在线免费观看| 老司机在线永久免费观看| 色乱码一区二区三区88| 偷偷色噜狠狠狠狠的777米奇| 欧美.日韩.国产.一区.二区| 国产精品吴梦梦| 国产在线你懂得| 色屁屁一区二区| 蜜桃传媒一区二区亚洲av | 欧美极度另类性三渗透| 国产精品无码白浆高潮| 国产精品三级久久久久三级| 丁香婷婷激情网| 欧美女王vk| 日本aⅴ大伊香蕉精品视频| 日本激情一区二区三区| 亚洲动漫第一页| 91人妻一区二区| 欧美freesex交免费视频| 亚洲www视频| 在线网址91| 日韩欧美国产综合| 欧美精品乱码视频一二专区| 国产电影精品久久禁18| 四虎精品欧美一区二区免费| 日韩精品一级| 久久久久久久久91| 蜜臀av午夜精品| 黄网动漫久久久| 蜜桃传媒一区二区亚洲| 日韩精品电影在线| 天天爽天天狠久久久| 国产精品66| 久久国产精品免费视频| 精品久久国产视频| 亚洲成av人在线观看| 日本69式三人交| 免费视频一区| 亚洲精品影院| 日本久久伊人| 午夜精品福利视频| 青青草在线免费视频| 日本道色综合久久| 中文字幕求饶的少妇| 国产在线日韩欧美| 无码 制服 丝袜 国产 另类| 免费电影一区二区三区| 日韩美女在线观看| 男人天堂手机在线| 精品久久久久久久久久久院品网 | av小次郎在线| 欧美精品一区二| 三级网站在线播放| 亚洲人123区| 国产国语性生话播放| 日本亚洲欧美天堂免费| 日本丰满大乳奶| 奇米777国产一区国产二区| 青青a在线精品免费观看| 男人天堂久久久| 亚洲风情亚aⅴ在线发布| 亚洲高清在线看| 樱花影视一区二区| 波多野结衣一本| 国产在线一区观看| 欧美日韩中文在线视频| 午夜精品久久久久久久四虎美女版| 成人情视频高清免费观看电影| 欧美日韩免费看片| 蜜臀久久99精品久久久久久宅男| 亚洲AV成人无码一二三区在线| 欧美日韩精品三区| 天天操天天爽天天干| 一区视频在线播放| 亚洲AV无码国产成人久久| 国产传媒日韩欧美成人| 不卡av免费在线| 在线看片成人| 糖心vlog在线免费观看| 免费成人结看片| 国产在线精品二区| **国产精品| 国产精品9999| 91豆花视频在线播放| 日韩在线视频观看正片免费网站| 欧洲av在线播放| 欧美一区二区成人6969| 中文字幕在线视频第一页| 欧美色播在线播放| avtt天堂在线| 中文字幕制服丝袜成人av| 免费观看av网站| 大美女一区二区三区| 91pony九色| 捆绑变态av一区二区三区| 91免费视频网站在线观看| 欧美色图首页| 伊人久久青草| 日本不卡高清| 日韩一区免费观看| 女人丝袜激情亚洲| 国产欧美韩日| 国产伦精品一区二区三区免费优势| 91亚洲国产成人精品性色| 黑人一区二区三区| 国产精品久久久999| 456成人影院在线观看| 国产91色在线播放| 亚洲女色av| 国产成人精品一区二区| a一区二区三区| 57pao成人国产永久免费| av剧情在线观看| 午夜免费日韩视频| 日韩欧美精品一区二区三区| 911国产网站尤物在线观看| 乱人伦视频在线| 8x拔播拔播x8国产精品| 成人免费看视频网站| 日本精品在线视频| 成人美女黄网站| 国产精品久久久久久久久久ktv| 素人一区二区三区| 国产欧美日韩中文字幕| 日韩成人一区| 96精品久久久久中文字幕| 精品伊人久久| 福利视频一区二区三区| 草草视频在线一区二区| 久草一区二区| 欧洲乱码伦视频免费| 亚洲三区视频| 欧美在线三级| 亚洲人成无码网站久久99热国产 | 9l视频白拍9色9l视频| 久久精品国产免费| 亚洲国产综合av| 国产·精品毛片| 欧洲一级黄色片| 欧美国产日产图区| 在线观看黄网址| 亚洲一区在线看| 日韩一区二区视频在线| 色八戒一区二区三区| 中文字幕在线观看1| 欧美一区二区三区四区久久 | 亚洲欧美一区二区激情| 电影av在线| 欧美另类极品videosbestfree| 99thz桃花论族在线播放| 国产成人av在线播放| 色婷婷成人网| 国产在线精品日韩| 日韩欧美午夜| 成人毛片一区二区| 蜜臀久久99精品久久久久久9| 亚洲欧美一区二区三区不卡| 99精品偷自拍| 亚洲欧洲综合网| 亚洲成人精品影院| 一级片视频播放| 亚洲а∨天堂久久精品喷水| 成年人在线观看网站| 欧美激情aaaa| 欧美精品资源| 国产精品一区二区免费| 日产午夜精品一线二线三线| 国产主播自拍av| 另类综合日韩欧美亚洲| 日韩av手机在线播放| 亚洲欧美日韩中文字幕一区二区三区 | 7m精品福利视频导航| 9999在线精品视频| 欧美黑人xxxxx| 国产精品va| 亚洲激情在线观看视频| 99综合电影在线视频| 国产精品 欧美激情| 在线观看一区日韩| 色欲av永久无码精品无码蜜桃| 色噜噜狠狠狠综合曰曰曰88av | 欧美国产小视频| 欧美在线观看成人| 国产成人精品免费看| 91av手机在线| 色综合网站在线| 色窝窝无码一区二区三区| 久久这里有精品视频| 成人性片免费| 日韩精品久久久免费观看| 黄色日韩在线| 丰满饥渴老女人hd| 国产精品福利影院| 亚洲精品一区二三区| 日韩av在线不卡| www欧美xxxx| 大波视频国产精品久久| 91精品国产调教在线观看| 欧美三级理论片| 久久久久久久精| 91视频免费网址| 亚洲经典中文字幕| 久久亚洲资源| 国产福利久久精品| 欧美日韩视频| 中文字幕一二三区| 亚洲女性喷水在线观看一区| 国产精品久久婷婷| 一区二区三区 在线观看视| 欧美最新精品| 欧美一区二区综合| 天堂在线亚洲视频| 久久久久久九九九九九| 91九色02白丝porn| 国产视频网站在线| 国产精品国产三级国产aⅴ浪潮| 美日韩中文字幕| 成人中文字幕av| 久久久久久久久99精品| 自拍偷拍18p| 中国日韩欧美久久久久久久久| 成人h在线观看| 一区二区三区在线视频看| 久久爱www久久做| 国产乱子轮xxx农村| 777久久久精品| 色图在线观看| 精品中文字幕人| 爽爽淫人综合网网站| 日本人亚洲人jjzzjjz| 欧美日韩成人在线| 国产三区视频在线观看| 北条麻妃高清一区| 亚洲乱码久久| www在线观看免费视频| 欧美色精品天天在线观看视频| 嫩草香蕉在线91一二三区| 99re6热在线精品视频播放速度| 亚洲视频碰碰| 免费观看a级片| 欧美疯狂做受xxxx富婆| 黄色网页网址在线免费| 国产精品久久久久av福利动漫| 性色一区二区三区| 国产传媒在线看| 日韩欧美激情四射| 激情黄产视频在线免费观看| 日韩视频精品| 国产在线视视频有精品| 精品欧美一区二区三区免费观看| 亚洲片av在线| 国产一区一区| 青青草原av在线播放| 国产精品超碰97尤物18| 亚洲男人天堂久久| 亲子乱一区二区三区电影| 91精品久久久久久久久久不卡| 亚洲av成人片无码| 欧美无砖专区一中文字| 黄色污污视频在线观看| 日韩精品国内| 成人97人人超碰人人99| 在线免费观看av片| 国内免费精品永久在线视频| 久久中文视频| 少妇饥渴放荡91麻豆|