国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

深入理解JVM自動內(nèi)存管理

 更新時間:2021年08月22日 11:16:44   作者:愛奇志  
對于Java虛擬機(jī)在內(nèi)存分配與回收的學(xué)習(xí),本文主要介紹了JVM自動內(nèi)存管理,文中通過圖文示例介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、前言

對于Java虛擬機(jī)在內(nèi)存分配與回收的學(xué)習(xí),如果讀者大學(xué)時代沒有偷懶的話,操作系統(tǒng)和計算機(jī)組成原理這兩門功課學(xué)的比較好的話,理解起來JVM是比較容易的,只要底子還在,很多東西都可以觸類旁通。

1.1 計算機(jī)==>操作系統(tǒng)==>JVM

JVM全稱為Java Virtual Machine,譯為Java虛擬機(jī),讀者會問,虛擬機(jī)虛擬的是誰呢?即虛擬是對什么東西的虛擬,即實(shí)體是什么,是如何虛擬的?下面讓我們來看看“虛擬與實(shí)體”。

​關(guān)于計算機(jī)、操作系統(tǒng)、JVM三者關(guān)系,如下圖:​

在這里插入圖片描述

1.1.1 虛擬與實(shí)體(對上圖的結(jié)構(gòu)層次分析)

JVM之所以稱為之虛擬機(jī),是因為它是實(shí)現(xiàn)了計算機(jī)的虛擬化。下表展示JVM位于操作系統(tǒng)堆內(nèi)存中,分別實(shí)現(xiàn)的了對操作系統(tǒng)和計算機(jī)的虛擬化。

在這里插入圖片描述

操作系統(tǒng)棧對應(yīng)JVM棧,操作系統(tǒng)堆對應(yīng)JVM堆,計算機(jī)磁盤對應(yīng)JVM方法區(qū),存放字節(jié)碼對象,計算機(jī)PC寄存器對應(yīng)JVM程序計數(shù)器(注意:計算機(jī)PC寄存器是下一條指令地址,JVM程序計數(shù)器是當(dāng)前指令的地址),

唯一不同的是,整個計算機(jī)(內(nèi)存(操作系統(tǒng)棧+操作系統(tǒng)堆)+磁盤+PC計數(shù)器)對應(yīng)JVM占用的整個內(nèi)存(JVM棧+JVM堆+JVM方法區(qū)+JVM程序計數(shù)器)。

1.1.2 Java程序執(zhí)行(對上圖的箭頭流程分析)

上圖中不僅是結(jié)構(gòu)圖,展示JVM的虛擬和實(shí)體的關(guān)系,也是一個流程圖,上圖中的箭頭展示JVM對一個對象的編譯執(zhí)行。

程序員寫好的類加載到虛擬機(jī)執(zhí)行的過程是:當(dāng)一個classLoder啟動的時候,classLoader的生存地點(diǎn)在JVM中的堆,首先它會去主機(jī)硬盤上將Test.class裝載到JVM的方法區(qū),方法區(qū)中的這個字節(jié)文件會被虛擬機(jī)拿來new Test字節(jié)碼(),然后在堆內(nèi)存生成了一個Test字節(jié)碼的對象,最后Test字節(jié)碼這個內(nèi)存文件有兩個引用一個指向Test的class對象,一個指向加載自己的classLoader。整個過程上圖用箭頭表示,這里做說明。

就像本文開始時說過的,有了計算機(jī)組成原理和操作系統(tǒng)兩門課的底子,學(xué)起JVM的時候會容易許多,因為JVM本質(zhì)上就是對計算機(jī)和操作系統(tǒng)的虛擬,就是一個虛擬機(jī)。

Java正是有了這一套虛擬機(jī)的支持,才成就了跨平臺(一次編譯,永久運(yùn)行)的優(yōu)勢。

這樣一來,前言部分我們成功引入JVM,接下來,本文要講述的重點(diǎn)是JVM自動內(nèi)存管理,先給出總述:

JVM自動內(nèi)存管理=分配內(nèi)存(指給對象分配內(nèi)存)+回收內(nèi)存(回收分配給對象的內(nèi)存)

上面公式告訴我們,JVM自動內(nèi)存管理分為兩塊,分配內(nèi)存和回收內(nèi)存

二、JVM內(nèi)存空間與參數(shù)設(shè)置

 2.1 運(yùn)行時數(shù)據(jù)區(qū)

JVM在執(zhí)行Java程序的過程中會把它所管理的內(nèi)存劃分為若干個不同的運(yùn)行時數(shù)據(jù)區(qū)域。這些運(yùn)行時數(shù)據(jù)區(qū)包括方法區(qū)、堆、虛擬棧、本地方法棧、程序計數(shù)器,如圖:

在這里插入圖片描述

讓我們一步步介紹,對于運(yùn)行時數(shù)據(jù)區(qū),很多博客都是使用順序介紹的方式,不利于讀者對比比較學(xué)習(xí),這里筆者以表格的方式呈現(xiàn):

程序計數(shù)器 Java虛擬機(jī)棧 本地方法棧 Java 堆 方法區(qū)
存放內(nèi)容 JVM字節(jié)碼指令的地址或Undefined(如果線程正在執(zhí)行一個 Java 方法,這個計數(shù)器記錄的是正在執(zhí)行的虛擬機(jī)字節(jié)碼指令的地址;如果正在執(zhí)行的是 Native 方法,這個計數(shù)器的值則為 (Undefined)) 局部變量表、操作數(shù)棧、動態(tài)鏈接、方法出口 Native方法(本地方法) 對象實(shí)例、數(shù)組 類信息、常量、靜態(tài)變量、即時編譯器編譯后的代碼
用途 字節(jié)碼解釋器工作是就是通過改變這個計數(shù)器的值來選取下一條需要執(zhí)行指令的字節(jié)碼指令,分支、循環(huán)、跳轉(zhuǎn)、異常處理、線程恢復(fù)等基礎(chǔ)功能都需要依賴計數(shù)器完成 每個方法在執(zhí)行時都會創(chuàng)建一個棧幀(Stack Frame)用于存儲局部變量表、操作數(shù)棧、動態(tài)鏈接、方法出口等信息。每一個方法從調(diào)用直至執(zhí)行結(jié)束,就對應(yīng)著一個棧幀從虛擬機(jī)棧中入棧到出棧的過程。 每一個本地方法的調(diào)用執(zhí)行過程,就對應(yīng)著一個棧幀從本地方法棧中入棧到出棧的過程。 用于存放對象實(shí)例,被對象引用所指向 存儲一個類型所使用到的所有類型,域和方法的符號引用,在java程序的動態(tài)鏈接中起核心作用
線程共享還是私有 線程私有 線程私有 線程私有 線程間共享 線程間共享
StackOverflowError棧溢出 線程請求的棧深度大于虛擬機(jī)所允許的深度。報錯信息:java.lang.StackOverflowError 線程請求的棧深度大于虛擬機(jī)所允許的深度。報錯信息:java.lang.StackOverflowError 線程請求的棧深度大于虛擬機(jī)所允許的深度。報錯信息:java.lang.StackOverflowError
OutOfMemoryError內(nèi)存泄露 如果虛擬機(jī)??梢詣討B(tài)擴(kuò)展,而擴(kuò)展時無法申請到足夠的內(nèi)存。報錯信息:java.lang.OutOfMemoryError:unable to create new native thread 如果虛擬機(jī)??梢詣討B(tài)擴(kuò)展,而擴(kuò)展時無法申請到足夠的內(nèi)存。報錯信息:java.lang.OutOfMemoryError:unable to create new native thread 如果堆中沒有內(nèi)存完成實(shí)例分配,并且堆也無法再擴(kuò)展時,拋出該異常。報錯信息:java.lang.OutOfMemoryError: Java heap space 當(dāng)方法區(qū)無法滿足內(nèi)存分配需求,拋出該異常。報錯信息:java.lang.OutOfMemoryError: PermGen space
特點(diǎn) 是五個區(qū)域中唯一一個沒有OutOfMemoryError Java虛擬機(jī)棧和本地方法棧都是方法調(diào)用棧,不同之處在于是一個是程序員編寫的Java方法,一個是自帶Native方法。 Java虛擬機(jī)棧和本地方法棧都是方法調(diào)用棧,不同之處在于是一個是程序員編寫的Java方法,一個是自帶Native方法。 1、可以位于物理上不連續(xù)的空間,但是邏輯上要連續(xù)。2、Java堆又稱為CG堆,分為新生區(qū)和老年區(qū),新生區(qū)又分為Eden區(qū)、From Survivor區(qū)和To Survivor 又稱為Non-Heap,非堆,與Java堆區(qū)分開來,

讓我們對上表繼續(xù)深入,講述上表中的StackOverflowError和OutOfMemoryError。

對于運(yùn)行時數(shù)據(jù)區(qū)的五個區(qū)域,如果討論生命周期,一般討論 堆 和 方法區(qū),因為其他三個是線程私有的,生命周期很簡單;

如果討論垃圾回收算法和垃圾收集器,一般只討論 堆,因為方法區(qū)里面存放的是要存活比較久的數(shù)據(jù),其他兩個棧和一個程序計數(shù)器僅保存了引用,只有堆中才是實(shí)際分配對象的,而要回收的就是對象;

如果討論 棧溢出,只討論本地方法棧和虛擬機(jī)棧,還有程序計數(shù)器;如果討論 內(nèi)存泄漏,討論后面四個,唯獨(dú)不討論程序計數(shù)器。

方法區(qū) 是 堆 邏輯的一部分,存放一些 類信息、常量、靜態(tài)變量、即時編譯器編譯后的代碼 ,為什么這些東西放到 方法區(qū) 里面而不是放到堆里面,因為這些是用很久的,不用回收的,所以這里沒有放到堆上(堆分為年輕代和老年代),經(jīng)常要回收,所以里面只能放經(jīng)常要回收的對象,又按照對象存活時間分為年輕代和老年代。

方法區(qū)JDK8之后變?yōu)橹苯觾?nèi)存,理由在于

2.2 關(guān)于StackOverflowError和OutOfMemoryError

2.2.1 StackOverflowError

運(yùn)行時數(shù)據(jù)區(qū)中,拋出棧溢出的就是虛擬機(jī)棧和本地方法棧,

產(chǎn)生原因:線程請求的棧深度大于虛擬機(jī)所允許的深度。因為JVM棧深度是有限的而不是無限的,但是一般的方法調(diào)用都不會超過JVM的棧深度,如果出現(xiàn)棧溢出,基本上都是代碼層面的原因,如遞歸調(diào)用沒有設(shè)置出口或者無限循環(huán)調(diào)用。

解決方法:程序員檢查代碼是否有無限循環(huán)即可。

2.2.2 OutOfMemoryError

容易發(fā)生OutOfMemoryError內(nèi)存溢出問題的內(nèi)存空間包括:Permanent Generation space和Heap space。

1、第一種java.lang.OutOfMemoryError: PermGen space(方法區(qū)拋出)

產(chǎn)生原因:發(fā)生這種問題的原意是程序中使用了大量的jar或class,使java虛擬機(jī)裝載類的空間不夠,與Permanent Generation space有關(guān)。所以,根本原因在于jar或class太多,方法區(qū)堆溢出,則解決方法有兩個種,要么增大方法區(qū),要么減少jar、class文件,且看解決方法。

解決方法:

從增大方法區(qū)方面入手:

增加java虛擬機(jī)中的XX:PermSize和XX:MaxPermSize參數(shù)的大小,其中XX:PermSize是初始永久保存區(qū)域大小,XX:MaxPermSize是最大永久保存區(qū)域大小。

如web應(yīng)用中,針對tomcat應(yīng)用服務(wù)器,在catalina.sh 或catalina.bat文件中一系列環(huán)境變量名說明結(jié)束處增加一行:
JAVA_OPTS=" -XX:PermSize=64M -XX:MaxPermSize=128m"
可有效解決web項目的tomcat服務(wù)器經(jīng)常宕機(jī)的問題。

從減少jar、class文件入手:

清理應(yīng)用程序中web-inf/lib下的jar,如果tomcat部署了多個應(yīng)用,很多應(yīng)用都使用了相同的jar,可以將共同的jar移到tomcat共同的lib下,減少類的重復(fù)加載。

2、第二種OutOfMemoryError: Java heap space(堆拋出)

產(chǎn)生原因:發(fā)生這種問題的原因是java虛擬機(jī)創(chuàng)建的對象太多,在進(jìn)行垃圾回收之間,虛擬機(jī)分配的到堆內(nèi)存空間已經(jīng)用滿了,與Heap space有關(guān)。所以,根本原因在于對象實(shí)例太多,Java堆溢出,則解決方法有兩個種,要么增大堆內(nèi)存,要么減少對象示例,且看解決方法。

解決方法:

1.從增大堆內(nèi)存方面入手:

增加Java虛擬機(jī)中Xms(初始堆大?。┖蚗mx(最大堆大小)參數(shù)的大小。如:set JAVA_OPTS= -Xms256m -Xmx1024m

2.從減少對象實(shí)例入手:

一般來說,正常程序的對象,堆內(nèi)存時絕對夠用的,出現(xiàn)堆內(nèi)存溢出一般是死循環(huán)中創(chuàng)建大量對象,檢查程序,看是否有死循環(huán)或不必要地重復(fù)創(chuàng)建大量對象。找到原因后,修改程序和算法。

3、第三種OutOfMemoryError:unable to create new native thread(Java虛擬機(jī)棧、本地方法棧拋出)

產(chǎn)生原因:這個異常問題本質(zhì)原因是我們創(chuàng)建了太多的線程,而能創(chuàng)建的線程數(shù)是有限制的,導(dǎo)致了異常的發(fā)生。能創(chuàng)建的線程數(shù)的具體計算公式如下:

(MaxProcessMemory - JVMMemory - ReservedOsMemory) / (ThreadStackSize) = Number of threads

注意:MaxProcessMemory 表示一個進(jìn)程的最大內(nèi)存,JVMMemory 表示JVM內(nèi)存,ReservedOsMemory 表示保留的操作系統(tǒng)內(nèi)存,ThreadStackSize 表示線程棧的大小。

在java語言里, 當(dāng)你創(chuàng)建一個線程的時候,虛擬機(jī)會在JVM內(nèi)存創(chuàng)建一個Thread對象同時創(chuàng)建一個操作系統(tǒng)線程,而這個系統(tǒng)線程的內(nèi)存用的不是JVMMemory,而是系統(tǒng)中剩下的內(nèi)存(MaxProcessMemory - JVMMemory - ReservedOsMemory)。由公式得出結(jié)論:你給JVM內(nèi)存越多,那么你能創(chuàng)建的線程越少,越容易發(fā)生 java.lang.OutOfMemoryError: unable to create new native thread

解決方法:

1.如果程序中有bug,導(dǎo)致創(chuàng)建大量不需要的線程或者線程沒有及時回收,那么必須解決這個bug,修改參數(shù)是不能解決問題的。
2.如果程序確實(shí)需要大量的線程,現(xiàn)有的設(shè)置不能達(dá)到要求,那么可以通過修改MaxProcessMemory,JVMMemory,ThreadStackSize這三個因素,來增加能創(chuàng)建的線程數(shù):MaxProcessMemory 表示使用64位操作系統(tǒng),VMMemory 表示減少 JVMMemory 的分配,ThreadStackSize 表示減小單個線程的棧大小。

2.3 JVM堆內(nèi)存和非堆內(nèi)存

2.3.1 堆內(nèi)存和非堆內(nèi)存

JVM內(nèi)存劃分為堆內(nèi)存和非堆內(nèi)存,堆內(nèi)存分為年輕代(Young Generation)、老年代(Old Generation),非堆內(nèi)存就一個永久代(Permanent Generation)。

年輕代又分為Eden和Survivor區(qū)。Survivor區(qū)由FromSpace和ToSpace組成。Eden區(qū)占大容量,Survivor兩個區(qū)占小容量,默認(rèn)比例是8:1:1。

堆內(nèi)存用途:存放的是對象,垃圾收集器就是收集這些對象,然后根據(jù)GC算法回收。

非堆內(nèi)存用途:永久代,也稱為方法區(qū),存儲程序運(yùn)行時長期存活的對象,比如類的元數(shù)據(jù)、方法、常量、屬性等。

在JDK1.8版本廢棄了永久代,替代的是元空間(MetaSpace),元空間與永久代上類似,都是方法區(qū)的實(shí)現(xiàn),他們最大區(qū)別是:永久代使用的是JVM的堆內(nèi)存空間,而元空間使用的是物理內(nèi)存,直接受到本機(jī)的物理內(nèi)存限制。在后面的實(shí)踐中,因為筆者使用的是JDK8,所以打印出的GC日志里面就有MetaSpace。

2.3.2 JVM堆內(nèi)部構(gòu)型(新生代和老年代)

Jdk8中已經(jīng)去掉永久區(qū),這里為了與時俱進(jìn),不再贅余。

在這里插入圖片描述

上圖演示Java堆內(nèi)存空間,分為新生代和老年代,分別占Java堆1/3和2/3的空間,新生代中又分為Eden區(qū)、Survivor0區(qū)、Survivor1區(qū),分別占新生代8/10、1/10、1/10空間。

問題1:什么是Java堆?

回答1:JVM規(guī)范中說到:”所有的對象實(shí)例以及數(shù)組都要在堆上分配”。Java堆是垃圾回收器管理的主要區(qū)域,百分之九十九的垃圾回收發(fā)生在Java堆,另外百分之一發(fā)生在方法區(qū),因此又稱之為”GC堆”。根據(jù)JVM規(guī)范規(guī)定的內(nèi)容,Java堆可以處于物理上不連續(xù)的內(nèi)存空間中。

問題2:為什么Java堆要分為新生代和老年代?

回答2:當(dāng)前JVM對于堆的垃圾回收,采用分代收集的策略。根據(jù)堆中對象的存活周期將堆內(nèi)存分為新生代和老年代。在新生代中,每次垃圾回收都有大批對象死去,只有少量存活。而老年代中存放的對象存活率高。這樣劃分的目的是為了使 JVM 能夠更好的管理堆內(nèi)存中的對象,包括內(nèi)存的分配以及回收。

問題3:為什么新生代要分為Eden區(qū)、Survivor0區(qū)、Survivor1區(qū)?

回答3:這是結(jié)構(gòu)與策略相適應(yīng)的原則,新生代垃圾收集使用的是復(fù)制算法(一種垃圾收集算法,Serial收集器、ParNew收集器、Parallel scavenge收集器都是用這種算法),復(fù)制算法可以很好的解決垃圾收集的內(nèi)存碎片問題,但是有一個天然的缺陷,就是要犧牲一半的內(nèi)存(即任意時刻只有一半內(nèi)存用于工作),這對于寶貴的內(nèi)存資源來說是極度奢侈的。新生代在使用復(fù)制算法作為其垃圾收集算法的時候,對其做了優(yōu)化,拿出2/10的新生代的內(nèi)存作為交換區(qū),稱為Survivor0區(qū)和Survivor1區(qū)(注意:有的博客上稱為From Survivor Space和To Survivor Space,這樣闡述也是對的,但是容易對初學(xué)者形成誤導(dǎo),因為在復(fù)制算法中,復(fù)制是雙向的,沒有固定的From和To,這一次是由這一邊到另一邊,下次就是從另一邊到這一邊,使用From Survivor Space和To Survivor Space容易讓后來學(xué)習(xí)者誤以為復(fù)制只能從一邊到另一邊,當(dāng)然有的博客中會附加不管從哪邊到哪邊,起始就是From,終點(diǎn)就是To,即From Survivor Space和To Survivor Space所對應(yīng)的區(qū)循環(huán)對調(diào),但是讀者不一定想的明白。所以筆者這里使用Survivor0、Survivor1,減少誤解)

所以說,新生代在結(jié)構(gòu)上分為Eden區(qū)、Survivor0區(qū)、Survivor1區(qū),是與其使用的垃圾收集算法(復(fù)制算法)相適應(yīng)的結(jié)果。

問題4:關(guān)于永久區(qū)Permanent Space?

回答4:Jdk8中取消了永久區(qū)Permanent Space,使用 元數(shù)據(jù)空間metaspace,使用直接內(nèi)存…

問題:什么是老年代擔(dān)保機(jī)制?
回答:因為新生代和老年代是1:2,如果在eden區(qū)放不下,會放到老年區(qū),如果minor gc的時候,survivor區(qū)放不下,也會放到老年區(qū),所有,有時候會在老年區(qū)里面有 不少gc年齡比較小 的大對象,就是因為年輕代放不下了,老年代擔(dān)保機(jī)制多次觸發(fā)會增加老年代負(fù)擔(dān),過早地觸發(fā)major gc,說明當(dāng)前的 eden survivor 比例設(shè)置不太好。

問題:為什么eden:survivor1:survivor2=8:1:1?
回答:這個可以設(shè)置的,VM Options: -XX:SurvivorRatio=8 新生代中Eden區(qū)域與Survivor區(qū)域的容量比值,默認(rèn)為8,代表Eden:Survivor=8:1。如果eden區(qū)域占比小,那么minor gc會比較頻繁,gc線程是占用cpu資源的,是stop the world的,不好;如果eden區(qū)域占比大,則survivor區(qū)域變小了,survivor區(qū)滿了也會觸發(fā)老年代擔(dān)保機(jī)制。

Minor GC觸發(fā)條件:eden區(qū)滿時,觸發(fā)MinorGC。即申請一個對象時,發(fā)現(xiàn)eden區(qū)不夠用,則觸發(fā)一次MinorGC。在MinorGC時,將小于 to space大小的存活對象復(fù)制到 to space(如果to space區(qū)域不夠,則利用擔(dān)保機(jī)制進(jìn)入老年代區(qū)域),然后to space和from space換位置,所以我們看到的to space一直是空的。

問題:為什么年輕代age是0~15,到了16就移動到老年代?
回答:對象頭中用四個bit位存放分代年齡,所以就是 0~15。

無論是對象大小還是對象年輕,進(jìn)入老年代的閾值都是可以用參數(shù)設(shè)置的,VM Options: -XX:PretenureSizeThreshold=3145728,表示大于3MB都到老年代中去;VM Options: -XX:MaxTenuringThreshold=2,表示經(jīng)歷兩次Minor GC,就到老年代中去。

問題:虛擬機(jī)怎么知道哪個對象要回收,哪個對象不回收?
回答:兩種方式:要么 引用計數(shù) ,要么 根節(jié)點(diǎn)+可達(dá)性分析。
引用計數(shù):這種方式有循環(huán)引用的問題,Java中不使用,python是使用。
解釋一下引用計數(shù),一般來說,java要回收的對象要求是沒有引用指向的,就是程序中沒有了用的對象,才可以回收,要求gc不影響程序??匆粋€循環(huán)引用的問題:

public class Main1 {
    public static void main(String[] args) {
        A a = new A();
        B b = new B();   // 這個時候 new A()對象和new B()對象引用計數(shù)為1,就是a b
        a.instance = b;
        b.instance = a;   // 這個時候 new A()對象和new B()對象引用計數(shù)為2,就是a b a.instance b.instance
        a = null;
        b = null;  // 這個時候 new A()對象和new B()對象已經(jīng)沒有引用了,但是引用計數(shù)仍然為1,instance還在指向
    }
}

class A {
     B instance;
}

class B {
     A instance;
}

對于 根節(jié)點(diǎn)+可達(dá)性分析,確定若干個根節(jié)點(diǎn),從根節(jié)點(diǎn)出發(fā),可以達(dá)到的就是可達(dá)的引用,所指向的對象不可回收,反之可以回收。如圖:

在這里插入圖片描述

obj1 引用指向?qū)ο?,obj2 引用指向?qū)ο?,obj3 引用指向?qū)ο?,而對象3 中又引用 對象4,對象5 不是 gc root,所以 對象5 和 對象6 都在可達(dá)性鏈 中。最終,對象1 對象2 對象3 對象4 都是可達(dá)的,不會被垃圾收集器回收,對象5 對象6 是不可達(dá)的,要被垃圾收集器回收。

2.4 JVM堆參數(shù)設(shè)置

這些都是和堆內(nèi)存分配有關(guān)的參數(shù),所以我們放在第二部分了,和垃圾收集器有關(guān)的參數(shù)放在第四部分。

舉例:java -Xmx3550m -Xms3550m -Xmn2g -Xss128k -XX:NewRatio=4 -XX:SurvivorRatio=4 -XX:MaxPermSize=16m

2.4.1 JVM重要參數(shù)

因為整個堆大小=年輕代大?。ㄐ律笮。?+ 年老代大小 + 持久代大小,

-Xmn2g:表示年輕代大小為2G。持久代一般固定大小為64m,所以增大年輕代后,將會減小年老代大小。此值對系統(tǒng)性能影響較大,Sun官方推薦配置為整個堆的3/8。

-XX:NewRatio=4:設(shè)置年輕代(包括Eden和兩個Survivor區(qū))與年老代的比值(除去持久代)。這里設(shè)置為4,表示年輕代與年老代所占比值為1:4,又因為上面設(shè)置年輕代為2G,則老年代大小為8G

-XX:SurvivorRatio=8:設(shè)置年輕代中Eden區(qū)與Survivor區(qū)的大小比值。這里設(shè)置為8,則兩個Survivor區(qū)與一個Eden區(qū)的比值為2:8,一個Survivor區(qū)占整個年輕代的1/10

則Eden:Survivor0:Survivor1=8:1:1

-XX:MaxPermSize=16m:設(shè)置持久代大小為16m。

所有整個堆大小=年輕代大小 + 年老代大小 + 持久代大小= 2G+ 8G+ 16M=10G+6M=10246MB

2.4.2 JVM其他參數(shù)

-Xmx3550m:設(shè)置JVM最大可用內(nèi)存為3550M。
-Xms3550m:設(shè)置JVM促使內(nèi)存為3550m,此值可以設(shè)置與-Xmx相同。

-Xss128k:設(shè)置每個線程的堆棧大小。JDK5.0以后每個線程堆棧大小為1M,以前每個線程堆棧大小為256K。更具應(yīng)用的線程所需內(nèi)存大小進(jìn)行調(diào)整。在相同物理內(nèi)存下,減小這個值能生成更多的線程。但是操作系統(tǒng)對一個進(jìn)程內(nèi)的線程數(shù)還是有限制的,不能無限生成,經(jīng)驗值在3000~5000左右。

關(guān)于為什么-xmx與-xms的大小設(shè)置為一樣的?

  • 首先,在Java堆內(nèi)存分配中,-xmx用于指定JVM最大分配的內(nèi)存,-xms用于指定JVM初始分配的內(nèi)存,所以,-xmx與-xms相等表示JVM初次分配的內(nèi)存的時候就把所有可以分配的最大內(nèi)存分配給它(指JVM),這樣的做的好處是:
  • 避免JVM在運(yùn)行過程中、每次垃圾回收完成后向OS申請內(nèi)存:因為所有的可以分配的最大內(nèi)存第一個就給它(JVM)了。
  • 延后啟動后首次GC的發(fā)生時機(jī)、減少啟動初期的GC次數(shù):因為第一次給它分配了最大的;
  • 盡可能避免使用swap space:swap space為交換空間,當(dāng)web項目部署到linux上時,有一條調(diào)優(yōu)原則就是“盡可能使用內(nèi)存而不是交換空間”
  • 設(shè)置堆內(nèi)存為不可擴(kuò)展和收縮,避免在每次GC 后調(diào)整堆的大小

影響堆內(nèi)存擴(kuò)展與收縮的兩個參數(shù)

MaxHeapFreeRadio MinHeapFreeRadio
默認(rèn)值為70 默認(rèn)值為40
當(dāng)xmx值比xms值大,堆可以動態(tài)收縮與擴(kuò)展,這個參數(shù)控制當(dāng)堆空間大于指定比例時會自動收縮,默認(rèn)表示堆空間大于70%會自動收縮 當(dāng)xmx值比xms值大,堆可以動態(tài)收縮與擴(kuò)展,這個參數(shù)控制當(dāng)堆空間小于指定比例時會自動擴(kuò)展,默認(rèn)表示堆空間小于40%會自動擴(kuò)展

由上表可知,堆內(nèi)存默認(rèn)是自動擴(kuò)展和收縮的,但是有一個前提條件,就是到xmx比xms大的時候,當(dāng)我們將xms設(shè)置為和xmx一樣大,堆內(nèi)存就不可擴(kuò)展和收縮了,即整個堆內(nèi)存被設(shè)置為一個固定值,避免在每次GC 后調(diào)整堆的大小。

附加:在Java非堆內(nèi)存分配中,一般是用永久區(qū)內(nèi)存分配:

JVM 使用 -XX:PermSize 設(shè)置非堆內(nèi)存初始值,由 -XX:MaxPermSize 設(shè)置最大非堆內(nèi)存的大小。

2.5 從日志看JVM(開發(fā)實(shí)踐)

在這里插入圖片描述

這里了設(shè)置GC日志關(guān)聯(lián)的類和將GC日志打印

在這里插入圖片描述

如程序所述,申請了10MB的空間,allocation1 2MB+allocation2 2MB+allocation3 2MB+allocation4 4MB=10MB

接下來我們開始閱讀GC日志,這里筆者以自己電腦上打印的GC日志為例,講述閱讀GC日志的方法:

heap表示堆,即下面的日志是對JVM堆內(nèi)存的打??;

因為使用的是jdk8,所以默認(rèn)使用ParallelGC收集器,也就是在新生代使用Parallel Scavenge收集器,老年代使用ParallelOld收集器

PSYoungGen 表示使用Parallel scavenge收集器作為年輕代收集器,ParOldGen表示使用Parallel old收集器作為老年代收集器,即筆者電腦上默認(rèn)是使用Parallel scavenge+Parallel old收集器組合。

其中,PSYoungGen總共38400K(37.5MB),被使用了13568K(13.25MB),PSYoungGen又分為Eden Space 33280K(32.5MB) 被使用了40% 13MB,from space 5120K(5MB)和to space 5120K(5MB),這就是一個eden區(qū)和兩個survivor區(qū)。

此處注意,因為使用的是jdk8,所以沒有永久區(qū)了,只有MetaSpace,見上圖。

三、HotSpot VM

3.1 HotSpot VM相關(guān)知識

問題一:什么是HotSpot虛擬機(jī)?HotSpot VM的前世今生?

回答一:HotSpot VM是由一家名為“Longview Technologies”的公司設(shè)計的一款虛擬機(jī),Sun公司收購Longview Technologies公司后,HotSpot VM成為Sun主要支持的VM產(chǎn)品,Oracle公司收購Sun公司后,即在HotSpot的基礎(chǔ)上,移植JRockit的優(yōu)秀特性,將HotSpot VM與JRockit VM整合到一起。

問題二:HotSpot VM有何優(yōu)點(diǎn)?

回答二:HotSpot VM的熱點(diǎn)代碼探測能力可以通過執(zhí)行計數(shù)器找出最具有編譯價值的代碼,然后通知JIT編譯器以方法為單位進(jìn)行編譯。如果一個方法被頻繁調(diào)用,或方法中有效循環(huán)次數(shù)很多,將會分別觸發(fā)標(biāo)準(zhǔn)編譯和OSR(棧上替換)編譯動作。 通過編譯器與解釋器恰當(dāng)?shù)貐f(xié)同工作,可以在最優(yōu)化的程序響應(yīng)時間與最佳執(zhí)行性能中取得平衡,而且無須等待本地代碼輸出才能執(zhí)行程序,即時編譯的時間壓力也相對減小,這樣有助于引入更多的代碼優(yōu)化技術(shù),輸出質(zhì)量更高的本地代碼。

問題三:HotSpot VM與JVM是什么關(guān)系?

回答三:今天的HotSpot VM,是Sun JDK和OpenJDK中所帶的虛擬機(jī),也是目前使用范圍最廣的Java虛擬機(jī)。

3.2 HotSpot VM的兩個實(shí)現(xiàn)與查看本機(jī)HotSpot

HotSpot VM包括兩個實(shí)現(xiàn),不同的實(shí)現(xiàn)適合不同的場景:

Java HotSpot Client VM:通過減少應(yīng)用程序啟動時間和內(nèi)存占用,在客戶端環(huán)境中運(yùn)行應(yīng)用程序時可以獲得最佳性能。此經(jīng)過專門調(diào)整,可縮短應(yīng)用程序啟動時間和內(nèi)存占用,使其特別適合客戶端環(huán)境。此jvm實(shí)現(xiàn)比較適合我們平時用作本地開發(fā),平時的開發(fā)不需要很大的內(nèi)存。

Java HotSpot Server VM:旨在最大程度地提高服務(wù)器環(huán)境中運(yùn)行的應(yīng)用程序的執(zhí)行速度。此jvm實(shí)現(xiàn)經(jīng)過專門調(diào)整,可能是特別調(diào)整堆大小、垃圾回收器、編譯器那些。用于長時間運(yùn)行的服務(wù)器程序,這些服務(wù)器程序需要盡可能快的運(yùn)行速度,而不是快速啟動時間。

只要電腦上安裝jdk,我們就可以看到hotspot的具體實(shí)現(xiàn):

在這里插入圖片描述

四、JVM內(nèi)存回收

我們知道,Java中是沒有析構(gòu)函數(shù)的,既然沒有析構(gòu)函數(shù),那么如何回收對象呢,答案是自動垃圾回收。Java語言的自動回收機(jī)制可以使程序員不用再操心對象回收問題,一切都交給JVM就好了。那么JVM又是如何做到自動回收垃圾的呢,且看本節(jié),本節(jié)分為兩個部分——垃圾收集算法和垃圾收集器,其中,收集算法是內(nèi)存回收的理論,而垃圾回收器是內(nèi)存回收的實(shí)踐。

垃圾收集策略兩個目的:gc次數(shù)少,gc時間短,不同的收集算法和收集器側(cè)重不同。

4.1 垃圾收集算法(內(nèi)存回收理論)

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

標(biāo)記-清除算法分為兩個階段,“標(biāo)記”和“清除”,

標(biāo)記:首先標(biāo)記出所有需要回收的對象;

清除:在標(biāo)記完成后統(tǒng)一回收所有被標(biāo)記的對象。

“標(biāo)記-清除”算法的不足:第一,效率問題,標(biāo)記和清除兩個過程的效率都不會太高;第二,空間問題,標(biāo)記清除后產(chǎn)生大量不連續(xù)的內(nèi)存碎片,這些內(nèi)存空間碎片可能會導(dǎo)致以后程序運(yùn)行過程中需要分配較大對象時,無法找到足夠的連續(xù)內(nèi)存而不得不提前觸發(fā)一次垃圾收集動作,如果很容易出現(xiàn)這樣的空間碎片多、無法找到大的連續(xù)空間的情況,垃圾收集就會較為頻繁。

4.1.2 復(fù)制算法

為了解決“標(biāo)記-清除算法”的效率問題,一種復(fù)制算法產(chǎn)生了,它將當(dāng)前可用內(nèi)存按容量劃分為大小相等的兩塊,每次只使用其中一塊。當(dāng)一塊的內(nèi)存用完了,就將還活著的對象復(fù)制到另一塊上面,然后再把已使用的內(nèi)存空間一次清除掉。這樣使得每次都對整個半?yún)^(qū)進(jìn)行內(nèi)存回收,內(nèi)存分配時就不用考慮內(nèi)存碎片等復(fù)雜情況,只要移動堆頂指針,按順序分配內(nèi)存即可。

這種算法處理內(nèi)存碎片的核心在于將整個半塊中活的的對象復(fù)制到另一整個半塊上面去,所以稱為復(fù)制算法。

附:關(guān)于復(fù)制算法的改進(jìn)

復(fù)制算法合理的解決了內(nèi)存碎片問題,但是卻要以犧牲一半的寶貴內(nèi)存為代價,這是非常讓人心疼的。令人愉快地是,現(xiàn)代虛擬機(jī)中,早就有了關(guān)于復(fù)制算法的改進(jìn):

對于Java堆中新生代中的對象來說,99%的對象都是“朝升夕死”的,就是說很多的對象在創(chuàng)建出來后不久就會死掉了,所有我們可以大膽一點(diǎn),不需要按照1:1的比例來劃分內(nèi)存空間,而是將新生代的內(nèi)存劃分為一塊較大的Eden區(qū)(一般占新生代8/10的大小)和兩塊較小的Survivor區(qū)(用于復(fù)制,一般每塊占新生代1/10的大小,兩塊占新生代2/10的大小)。當(dāng)回收時,將Eden區(qū)和Survivor里面當(dāng)前還活著的對象全部都復(fù)制到另一塊Survivor中(關(guān)于另一個塊Survivor是否會溢出的問題,答案是不會,這里將新生代90%的容量里的對象復(fù)制到10%的容量里面,確實(shí)是有風(fēng)險的,但是JVM有一種內(nèi)存的分配擔(dān)保機(jī)制,即當(dāng)目的Survivor空間不夠,會將多出來的對象放到老年代中,因為老年代是足夠大的),最后清理Eden區(qū)和源Survivor區(qū)的空間。這樣一來,每次新生代可用內(nèi)存空間為整個新生代90%,只有10%的內(nèi)存被浪費(fèi)掉,

正是因為這一特性,現(xiàn)代虛擬機(jī)中采用復(fù)制算法來回收新生代,如Serial收集器、ParNew收集器、Parallel scavenge收集器均是如此。

4.1.3 標(biāo)志-整理算法(復(fù)制算法變更后在老年代的應(yīng)用)

對于新生代來說,由于具有“99%的對象都是朝生夕死的”這一特點(diǎn),所以我們可以大膽的使用10%的內(nèi)存去存放90%的內(nèi)存中活著的對象,即使是目的Survivor的容量不夠,也可以將多余的存放到老年代中(擔(dān)保機(jī)制),所有對于新生代,我們使用復(fù)制算法是比較好的(Serial收集器、ParNew收集器、Parallel scavenge收集器)。

但是對于老年代,沒有大多數(shù)對象朝生夕死這一特點(diǎn),如果使用復(fù)制算法就要浪費(fèi)一半的寶貴內(nèi)存,所有我們用另一種辦法來處理它(指老年代)——標(biāo)志-整理算法。

標(biāo)記-整理算法分為兩個階段,“標(biāo)記”和“整理”,

標(biāo)記:首先標(biāo)記出所有需要回收的對象(和標(biāo)記-清除算法一樣);

整理:在標(biāo)記完成后讓所有存活的對象都向一端移動,然后直接清理掉端邊界以外的內(nèi)存(向一端移動類似復(fù)制算法)。

區(qū)別:標(biāo)志-清除算法包括先標(biāo)志,后清除兩個過程,標(biāo)志-整理算法包括先標(biāo)志,后清除,再整理三個過程。

4.1.4 分代收集算法

當(dāng)前商業(yè)虛擬機(jī)都是的垃圾收集都使用“分代收集”算法,這種算法并沒有什么新的思想,只是根據(jù)對象存活周期的不同將內(nèi)存劃分為幾塊。一般是把Java堆分為新生代和老年代,這樣就可以根據(jù)各個年代的特點(diǎn)采取最適當(dāng)?shù)氖占惴ā?/p>

在新生代中,每次垃圾收集時都發(fā)現(xiàn)有大批對象死去,只有少量對象存活,就是使用復(fù)制算法,這樣只需要付出少量存活對象的復(fù)制成本就可以完成收集。而老年代中因為對象的存活率高、沒有額外空間對其分配擔(dān)保(新生代復(fù)制算法如果目的Survivor容量不夠會將多余對象放到老年代中,這就是老年代對新生代的分配擔(dān)保),必須使用“標(biāo)記-清除算法”或“標(biāo)記-整理算法”來回收。

新生代的minor gc頻率較高,復(fù)制算法正好浪費(fèi)一半空間,不用整理內(nèi)存空間碎片,以空間換時間;
老年代的major gc頻率較低,“標(biāo)記-整理算法”包括先標(biāo)志、再清除,最后整理,整理內(nèi)存碎片需要時間,但是整個算法不浪費(fèi)空間,以時間換空間。

四種常用算法優(yōu)缺點(diǎn)比較、用途比較

在這里插入圖片描述

4.2 垃圾收集器(內(nèi)存回收實(shí)踐)

有了上面的垃圾回收算法,就有了很多的垃圾回收器。對于垃圾回收器,很少有表格對比,筆者以表格對比的方式呈現(xiàn):

單線程or多線程 新生代or老年代 基于的收集算法 備注
Serial收集器 單線程 新生代 復(fù)制算法 優(yōu)點(diǎn):簡單; 缺點(diǎn):Stop the world,垃圾收集時要停掉所有其他線程; 常用組合:Serial + serial old 新生代和老年代都是單線程,簡單
ParNew收集器(是Serial收集器的多線程版本) 多線程 新生代 復(fù)制算法 優(yōu)點(diǎn):相對于Serial收集器,使用了多線程; 缺點(diǎn):除了多線程,其他所有和Serial收集器一樣; 常用組合:ParNew+ serial old 新生代多線程,老年代單線程,簡單(新生代ParNew收集器僅僅是Serial收集器的多線程版本,所有該組合相對于Serial + serial old 只是新生代是多線程而已,其余不變)
Parallel scavenge收集器(吞吐量優(yōu)先收集器) 多線程 新生代 復(fù)制算法 設(shè)計目標(biāo):盡可能達(dá)到一個可控制的吞吐量; 吞吐量=運(yùn)行用戶代碼時間/(運(yùn)行用戶代碼時間+來及收集時間); 優(yōu)點(diǎn):吞吐量高,可以高效率地利用CPU時間,盡快完成程序的計算任務(wù),適合后臺運(yùn)算; 缺點(diǎn):沒有太大缺陷; 常用組合:Parallel scavenge + Parallel old 該組合完成吞吐量優(yōu)先虛擬機(jī),適用于后臺計算;
serial old收集器(是Serial收集器的老年代版本) 單線程 老年代 標(biāo)記-整理算法 優(yōu)點(diǎn):簡單; 缺點(diǎn):Stop the world,垃圾收集時要停掉所有其他線程; 常用組合:Serial + serial old 新生代和老年代都是單線程,簡單;
Parallel old收集器(是Parallel scavenge收集器的老年代版本) 多線程 老年代 標(biāo)記-整理算法 優(yōu)點(diǎn):吞吐量高,可以高效率地利用CPU時間,盡快完成程序的計算任務(wù),適合后臺運(yùn)算; 缺點(diǎn):沒有太大缺陷; 常用組合:Parallel scavenge + Parallel old 該組合完成吞吐量優(yōu)先虛擬機(jī),適用于后臺計算;
cms收集器(并發(fā)低停頓收集器) 多線程 老年代 標(biāo)記-清除算法 優(yōu)點(diǎn):停頓時間短,適合與用戶交互的程序;四個步驟:初始標(biāo)記 CMS initial mark、并發(fā)標(biāo)記 CMS concurrent mark、重新標(biāo)記 CMS remark、并發(fā)清除 CMS concurrent sweep;常用組合:cms收集器 完成響應(yīng)時間短虛擬機(jī),適用于用戶交互;
G1收集器 多線程 新生代+老年代 標(biāo)記-整理算法 面向服務(wù)端的垃圾回收器。特點(diǎn):并行與并發(fā)、分代收集、空間整合、可預(yù)測的停頓;四個步驟:初始標(biāo)記 Initial Marking、并發(fā)標(biāo)記 Concurrent Marking、最終篩選 Final Marking 、篩選回收 Live Data Counting and Evacuation;常用組合:G1收集器 面向服務(wù)端的垃圾回收器注意:G1收集器的收集算法加粗了,這里做出說明,G1收集器從整體上來看是基于“標(biāo)記-整理”算法實(shí)現(xiàn)的收集器,從局部(兩個region之間)上看來是基于“復(fù)制”算法實(shí)現(xiàn)的。

注意:G1收集器的收集算法加粗了,這里做出說明,G1收集器從整體上來看是基于“標(biāo)記-整理”算法實(shí)現(xiàn)的收集器,從局部(兩個region之間)上看來是基于“復(fù)制”算法實(shí)現(xiàn)的。

從上表可以得到的收集常用組合包括:

常用組合1:Serial + serial old 新生代和老年代都是單線程,簡單

常用組合2:ParNew+ serial old 新生代多線程,老年代單線程,簡單

常用組合3:Parallel scavenge + Parallel old 該組合完成吞吐量優(yōu)先虛擬機(jī),適用于后臺計算

常用組合4:cms收集器 完成響應(yīng)時間短虛擬機(jī),適用于用戶交互

常用組合5:G1收集器 面向服務(wù)端的垃圾回收器

4.2.1 常用組合1:Serial + serial old 新生代和老年代都是單線程,簡單

在這里插入圖片描述

附:圖上有一個safepoint,譯為安全點(diǎn)(有的博客上寫成了savepoint,是錯誤的,至少是不準(zhǔn)確的),這個safepoint干什么的呢?如何確定這個safepoint的位置?

這個safepoint是干什么的?

safepoint的定義是“A point in program where the state of execution is known by the VM”,譯為程序中一個點(diǎn)就是虛擬機(jī)所知道的一個執(zhí)行狀態(tài)。

JVM中safepoint有兩種,分別為GC safepoint、Deoptimization safepoint:

GC safepoint:用在垃圾收集操作中,如果要執(zhí)行一次GC,那么JVM里所有需要執(zhí)行GC的Java線程都要在到達(dá)GC safepoint之后才可以開始GC;

Deoptimization safepoint:如果要執(zhí)行一次deoptimization,那么JVM里所有需要執(zhí)行deoptimization的Java線程都要在到達(dá)deoptimization safepoint之后才可以開始deoptimize

我們上圖中的safepoint自然是GC safepoint,所以上圖中的兩個safepoint都是指執(zhí)行GC線程前的狀態(tài)。

對于上圖的理解是(很多博客上都有這種運(yùn)行示意圖,但是沒有加上解釋,筆者這里加上):

1、多個用戶線程(圖中是四個)要開始執(zhí)行新生代GC操作,所以都要達(dá)到GC safepoint點(diǎn),先到的要等待晚到的,圖中都達(dá)到了;

2、四個線程都執(zhí)行新生代的GC操作,因為使用的是Serial收集器,所以是基于復(fù)制算法的單線程GC,而且要Stop the world,所以只有GC線程在執(zhí)行,四個用戶線程都停止了。

3、新生代GC操作完成,四個線程繼續(xù)執(zhí)行,過了一會兒,要開始執(zhí)行老年代的GC操作了,所以四個線程都要再次達(dá)到GC safepoint點(diǎn),先到的要等待晚到的,圖中都達(dá)到了;

4、四個線程都執(zhí)行老年代的GC操作,因為使用的是Serial Old收集器,所以是基于標(biāo)志-整理算法的單線程GC,而且要Stop the world,所以只有GC線程在執(zhí)行,四個用戶線程都停止了。

5、老年代GC操作完成,四個線程繼續(xù)執(zhí)行。

4.2.2 常用組合2:ParNew+ serial old 新生代多線程,老年代單線程,簡單

在這里插入圖片描述

該組合中新生代ParNew收集器僅僅是Serial收集器的多線程版本,所有該組合相對于Serial + serial old 只是新生代是多線程而已,其余不變

對于上圖的理解是(很多博客上都有這種運(yùn)行示意圖,但是沒有加上解釋,筆者這里加上):

1、多個用戶線程(圖中是四個)要開始執(zhí)行新生代GC操作,所以都要達(dá)到GC safepoint點(diǎn),先到的要等待晚到的,圖中都達(dá)到了;

2、四個線程都執(zhí)行新生代的GC操作,因為使用的是Parnew收集器,所以是基于復(fù)制算法的多線程GC(注意,這里的多線程GC,是指多個GC線程并發(fā),用戶線程還是要停止的)所以還是要Stop the world,所以只有GC線程在執(zhí)行,四個用戶線程都停止了。

3、新生代GC操作完成,四個線程繼續(xù)執(zhí)行,過了一會兒,要開始執(zhí)行老年代的GC操作了,所以四個線程都要再次達(dá)到GC safepoint點(diǎn),先到的要等待晚到的,圖中都達(dá)到了;

4、四個線程都執(zhí)行老年代的GC操作,因為使用的是Serial Old收集器,所以是基于標(biāo)志-整理算法的單線程GC,而且要Stop the world,所以只有GC線程在執(zhí)行,四個用戶線程都停止了。

5、老年代GC操作完成,四個線程繼續(xù)執(zhí)行。

4.2.3 常用組合3:Parallel scavenge + Parallel old 新生代和老年代都是多線程,該組合完成吞吐量優(yōu)先虛擬機(jī),適用于后臺計算

在這里插入圖片描述

對于上圖的理解是:

1、多個用戶線程(圖中是四個)要開始執(zhí)行新生代GC操作,所以都要達(dá)到GC safepoint點(diǎn),先到的要等待晚到的,圖中都達(dá)到了;

2、四個線程都執(zhí)行新生代的GC操作,因為使用的是Parallel scavenge收集器,所以是基于復(fù)制算法的多線程GC(注意,這里的多線程GC,是指多個GC線程并發(fā),用戶線程還是要停止的)所以只有GC線程在執(zhí)行,四個用戶線程都停止了。

3、新生代GC操作完成,四個線程繼續(xù)執(zhí)行,過了一會兒,要開始執(zhí)行老年代的GC操作了,所以四個線程都要再次達(dá)到GC safepoint點(diǎn),先到的要等待晚到的,圖中都達(dá)到了;

4、四個線程都執(zhí)行老年代的GC操作,因為使用的是Parallel Old收集器,所以是基于標(biāo)志-整理算法的多線程GC,(注意,這里的多線程GC,是指多個GC線程并發(fā),用戶線程還是要停止的)所以只有GC線程在執(zhí)行,四個用戶線程都停止了。

5、老年代GC操作完成,四個線程繼續(xù)執(zhí)行。

4.2.4 常用組合4:cms收集器 多線程,完成響應(yīng)時間短虛擬機(jī),適用于用戶交互

在這里插入圖片描述

對于上圖的理解是:

CMS收集包括四個步驟:初始標(biāo)記、并發(fā)標(biāo)記、重新標(biāo)記、并發(fā)清除(CMS作為標(biāo)記-清除收集器,三個標(biāo)記一個清除)

在這里插入圖片描述

1、多個用戶線程(圖中是四個)要開始執(zhí)行新生代GC操作,所以都要達(dá)到GC safepoint點(diǎn),先到的要等待晚到的,圖中都達(dá)到了;

2、四個線程都執(zhí)行GC操作,因為使用的是CMS收集器,第一步驟是初始標(biāo)記,初始標(biāo)記僅僅只是標(biāo)記一下GC Roots能直接關(guān)聯(lián)到的對象,GC的標(biāo)記階段需要stop the world,讓所有Java線程掛起,這樣JVM才可以安全地來標(biāo)記對象。所以只有“初始標(biāo)記”在執(zhí)行,四個用戶線程都停止了。初始標(biāo)記完成后,達(dá)到第二個GC safepoint,圖中達(dá)到了;

3、開始執(zhí)行并發(fā)標(biāo)記,并發(fā)標(biāo)記是GCRoot開始對堆中的對象進(jìn)行可達(dá)性分析,找出存活的對象,并發(fā)標(biāo)記可以與用戶線程一起執(zhí)行,并發(fā)標(biāo)記完成后,所有線程達(dá)到下一個GC safepoint,圖中達(dá)到了;

4、開始執(zhí)行重新標(biāo)記,重新標(biāo)記是為了修正在并發(fā)標(biāo)記期間因用戶程序繼續(xù)運(yùn)作而導(dǎo)致標(biāo)記產(chǎn)生變動的那部分標(biāo)記記錄,

重新標(biāo)記完成后,所有線程達(dá)到下一個GC safepoint,圖中達(dá)到了;

5、開始執(zhí)行并發(fā)清理,并發(fā)清理可以與用戶線程一起執(zhí)行,并發(fā)清理完成后,所有線程達(dá)到下一個GC safepoint,圖中達(dá)到了;

6、開始重置線程,就是對剛才并發(fā)標(biāo)記操作的對象,圖中是線程3(注意:重置線程針對的是并發(fā)標(biāo)記的線程,沒有被并發(fā)標(biāo)記的線程不需要重置線程操作),重置操作線程3的時候,與其他三個用戶線程無關(guān),它們可以一起執(zhí)行。

CMS為什么是多線程收集器?

因為CMS收集器整個過程中耗時最長的第二并發(fā)標(biāo)記和第四并發(fā)清除過程中,GC線程都可以與用戶線程一起工作,初始標(biāo)記和重新標(biāo)記時間忽略不計,所以,從總體上來說,cms收集器的內(nèi)存回收過程與用戶線程是并發(fā)執(zhí)行的,所以上表中CMS為多線程收集器。

4.2.5 常用組合5:G1收集器 多線程,面向服務(wù)端的垃圾回收器

G1收集器是一款比CMS更優(yōu)秀的收集器,所以取代了cms,成為現(xiàn)在虛擬機(jī)的內(nèi)置收集器,它將整個Java堆劃分為多個大小相等的獨(dú)立區(qū)域,即Region,雖然還保留新生代和老年代的概念,但新生代和老年代已不再物理隔離,僅僅是邏輯分區(qū),它們都是一部分Region的集合,如下圖:

在這里插入圖片描述

每個region內(nèi)部必須是邏輯連續(xù)的,一個大小限制為 1M ~ 32M 之間,數(shù)量為 2048 個region,所以整個收集器 大小為 2G ~ 64G 。region 分為五種,Empty就是空白region,eden 和 survivor 都是年輕代,使用復(fù)制算法,old 是老年代,使用 標(biāo)志-整理算法(先標(biāo)記,再清除,最后整理),還有一個 Humongous region,是用來存放大對象的。

G1收集器的精髓1:G1 英文全名為 Garage First,就是 垃圾優(yōu)先 的意思,內(nèi)置 region 價值分析算法,垃圾收集的時候,會跟蹤各個Region里面的垃圾堆積的價值大小(回收所獲得的空間大小以及回收所需時間的經(jīng)驗值),在后臺維護(hù)一個優(yōu)先列表,每次依據(jù)允許的收集時間,優(yōu)先收集回收價值最大的Region。正是這種使用Region劃分內(nèi)存空間以及有優(yōu)先級的區(qū)域回收方式,保證了G1收集器在有限時間內(nèi)可以獲取盡可能高的效率,就是 垃圾優(yōu)先 的精髓。

G1收集器的精髓2:不僅如此,在 G1 收集器中,各個region不是物理分區(qū),僅僅邏輯分區(qū),region的身份是可以切換的,比如一個 old region 經(jīng)過價值分析被選中后,就會被收集,收集之后就變成了 empty region,然后下一次就可以和旁邊的 eden region 連續(xù)起來,就可以分配 新對象 或 大對象了,這種 region 身份切換 讓 G1 收集器不受固定分區(qū)的影響,更靈活的處理垃圾收集,這個其他的垃圾收集器所不具備的。

region 一共八個身份/角色

在這里插入圖片描述

FreeTag 空閑區(qū)域
Young Eden SurvTag 年輕代區(qū)域,分為Eden 和 Surv 兩種
HumStartTag 大對象頭部區(qū)域
HumContTag 大對象連續(xù)區(qū)域
OldTag 老年代對象

注意:單個region大小范圍為 1M ~ 32M,當(dāng)對象大小超過單個region大小的一半,則會被認(rèn)為是大對象,放到Humongous里面,大對象有 HumStartTag + N 個 HumContTag 構(gòu)成,所以用兩種標(biāo)記。

G1收集器運(yùn)行示意圖如下:

在這里插入圖片描述

對于上圖的理解是:

G1收集包括四個步驟:初始標(biāo)記、并發(fā)標(biāo)記、最終篩選、篩選回收

1、多個用戶線程(圖中是四個)要開始執(zhí)行新生代GC操作,所以都要達(dá)到GC safepoint點(diǎn),先到的要等待晚到的,圖中都達(dá)到了;

2、開始執(zhí)行初始標(biāo)記,初始標(biāo)記僅僅只是標(biāo)記一下GC Roots能直接關(guān)聯(lián)到的對象,并且修改TAMS(Next Top at Mark Start)的值,讓下一個階段用戶程序并發(fā)標(biāo)記時,能在正確可用的Region上創(chuàng)建新對象,整個標(biāo)記階段需要stop the world,讓所有Java線程掛起,這樣JVM才可以安全地來標(biāo)記對象。所以只有“初始標(biāo)記”在執(zhí)行,四個用戶線程都停止了。初始標(biāo)記完成后,達(dá)到第二個GC safepoint,圖中達(dá)到了;

3、開始執(zhí)行并發(fā)標(biāo)記,并發(fā)標(biāo)記是GCRoot開始對堆中的對象進(jìn)行可達(dá)性分析,找出存活的對象,并發(fā)標(biāo)記可以與用戶線程一起執(zhí)行,并發(fā)標(biāo)記完成后,所有線程(GC線程、用戶線程)達(dá)到下一個GC safepoint,圖中達(dá)到了;

4、開始執(zhí)行最終標(biāo)記,最終標(biāo)記是為了修正在并發(fā)標(biāo)記期間因用戶程序繼續(xù)運(yùn)作而導(dǎo)致標(biāo)記產(chǎn)生變動的那部分標(biāo)記記錄,最終標(biāo)記完成后,所有線程達(dá)到下一個GC safepoint,圖中達(dá)到了;

5、開始執(zhí)行篩選回收,篩選回歸首先對各個Region的回收價值和成本排序, 根據(jù)用戶期待的GC停頓時間來制定回收計劃,篩選回收過程中,因為停頓用戶線程將大幅提高收集效率,所以一般篩選回歸是停止用戶線程的,篩選回歸完成后,所有線程達(dá)到下一個GC safepoint,圖中達(dá)到了;

6、G1收集器收集結(jié)束,繼續(xù)并發(fā)執(zhí)行用戶線程。

4.3 垃圾收集器常用參數(shù)

(筆者這里加上idea上如何使用這些參數(shù),這些是垃圾收集器的參數(shù),所以這里放到第四部分,在本文第五部分內(nèi)存分配我們會用到)

參數(shù) idea中使用方式 描述
UseSerialGC VM Options:-XX:+UseSerialGC 虛擬機(jī)運(yùn)行在Client模式下的默認(rèn)值,打開此開關(guān)之后,使用Serial+Serial Old的收集器組合進(jìn)行內(nèi)存回收
UseParNewGC VM Options: -XX:+UseParNewGC 打開此開關(guān)之后,使用ParNew+ Serial Old的收集器組合進(jìn)行內(nèi)存回收
UseConcMarkSweepGC VM Options: -XX:+UseConcMarkSweepGC 打開此開關(guān)之后,使用ParNew + CMS+ Serial Old的收集器組合進(jìn)行內(nèi)存回收。Serial Old收集器將作為CMS收集器出現(xiàn)Concurrent Mode Failure失敗后的后備收集器使用
UseParallelGC VM Options: -XX:+UseParallelGC 虛擬機(jī)運(yùn)行在Server模式下的默認(rèn)值,打開此開關(guān)之后,使用Parallel Scavenge + Serial Old(PS MarkSweep)的收集器組合進(jìn)行內(nèi)存回收
UseParallelOldGC VM Options: -XX:UseParallelOldGC 打開此開關(guān)后,使用Parallel Scavenge + Parallel Old 的收集器組合進(jìn)行內(nèi)存回收
SurvivorRatio VM Options: -XX:SurvivorRatio=8 新生代中Eden區(qū)域與Survivor區(qū)域的容量比值,默認(rèn)為8,代表Eden:Survivor=8:1
PretenureSizeThreshold VM Options: -XX:PretenureSizeThreshold=3145728,表示大于3MB都到老年代中去 直接晉升到老年代的對象大小,設(shè)置這個參數(shù)后,這個參數(shù)以字節(jié)B為單位大于這個參數(shù)的對象將直接在老年代中分配
MaxTenuringThreshold VM Options: -XX:MaxTenuringThreshold=2,表示經(jīng)歷兩次Minor GC,就到老年代中去 晉升到老年代的對象年齡,每個對象在堅持過一次Minor GC之后,年齡就增加1,當(dāng)超過這個參數(shù)值就進(jìn)入到老年代
UseAdaptiveSizePolicy VM Options: -XX:+UseAdaptiveSizePolicy 動態(tài)調(diào)整Java堆中各個區(qū)域的大小以及進(jìn)入老年代的年齡
HandlePromotionFailure jdk1.8下,HandlePromotionFailure會報錯,Unrecongnized VM option 是否允許分配擔(dān)保失敗,即老年代的剩余空間不足應(yīng)應(yīng)對新生代的整個Eden區(qū)和Survivor區(qū)的所有對象存活的極端情況
ParallelGCThreads VM Options: -XX:ParallelGCThreads=10 設(shè)置并行GC時進(jìn)入內(nèi)存回收線程數(shù)
GCTimeRadio VM Options: -XX:GCTimeRadio=99 GC占總時間的比率,默認(rèn)值是99,即允許1%的GC時間,僅在使用Parallel Scavenge收集器時生效
MaxGCPauseMillis VM Options:-XX:MaxGCPauseMillis=100 設(shè)置GC的最大停頓時間,僅在使用Parallel Scavenge收集器時生效
CMSInitiatingOccupanyFraction VM Options:-XX:CMSInitiatingOccupanyFraction=68 設(shè)置CMS收集器在老年代空間被使用多少后觸發(fā)垃圾收集,默認(rèn)值68%,僅在使用CMS收集器時生效
UseCMSCompactAtFullCollection VM Options: -XX:+UseCMSCompactAtFullCollection 設(shè)置CMS收集器在完成垃圾收集后是否要進(jìn)行一次內(nèi)存碎片的整理,僅在使用CMS收集器時生效
CMSFullGCsBeforeCompaction VM Options:-XX:CCMSFullGCsBeforeCompaction=10 設(shè)置CMS收集在進(jìn)行若干次垃圾收集后再啟動一次內(nèi)存碎片整理,僅在使用CMS收集器時生效

五、JVM內(nèi)存分配

新生代GC(Minor GC):發(fā)生在新生代的垃圾收集動作,因為Java對象大多具有朝生夕滅的特性,所有Minor GC非常頻繁,一般回收速度較快。

老年代GC(Major GC/):發(fā)生在老年代的GC,出現(xiàn)了major GC,經(jīng)常會伴隨一個MinorGC(但是不絕對),Major GC速度一般比Minor GC慢10倍。

在JVM中,GC分為 full Gc 和 partition gc兩種,full gc是指新生代,老年代,永久區(qū)都gc,即全局gc,其他的所有的,minor gc 和 major gc 都是partion gc。

Major GC 是清理永久代。
Full GC 是清理整個堆空間—包括年輕代和永久代。

5.1 對象優(yōu)先在Eden上分配

5.1.1 設(shè)置VM Options

-XX:+PrintGCDetails             //打印GC日志
-Xms20M                              //初始堆大小為20M
-Xmx20M        //最大堆大小為20M
-Xmn10M           //年輕代大小為10M,則老年代大小=堆大小20M-年輕代大小10M=10M
-XX:SurvivorRatio=8     //年輕代 Eden:Survivor=8  則Eden為8M  Survivor0為1M  Survivor1為1M
-XX:+UseSerialGC       //筆者使用的jdk8默認(rèn)為Parallel scavenge+Parallel old收集器組合,書上使用Serial+Serial Old的收集器組合,這里設(shè)置好

5.1.2 程序輸出(給出附加解釋)

第一步:可以看到,當(dāng)分配6M內(nèi)存時,全部都在Eden區(qū),沒有任何問題,說明JVM優(yōu)先在Eden區(qū)上分配對象

在這里插入圖片描述

第二步:因為年輕代只有9M,剩下1M是給To Survivor用的,已經(jīng)使用了6M,現(xiàn)在申請4M, 就會觸發(fā)Minor GC,將6M的存活的對象放到目的survivor中去,但是放不下,因為目的survivor只有1M空間,所以分配擔(dān)保到老年代中去,然后將4M對象放到Eden區(qū)中。所以,最后的結(jié)果是 Eden區(qū)域使用了4096KB 4M 老年代中使用了6M 這里form space占用57%可以忽略不計。

在這里插入圖片描述

5.2 大對象直接進(jìn)入老年代(使用-XX:PretenureSizeThreshold參數(shù)設(shè)置)

5.2.1 設(shè)置VM Options

-XX:+PrintGCDetails             //打印GC日志
-Xms20M                              //初始堆大小為20M
-Xmx20M        //最大堆大小為20M
-Xmn10M           //年輕代大小為10M,則老年代大小=堆大小20M-年輕代大小10M=10M
-XX:SurvivorRatio=8     //年輕代 Eden:Survivor=8  則Eden為8M  Survivor0為1M  Survivor1為1M
-XX:+UseSerialGC       //筆者使用的jdk8默認(rèn)為Parallel scavenge+Parallel old收集器組合,書上使用Serial+Serial Old的收集器組合,這里設(shè)置好
-XX:PretenureSizeThreshold=3145728    // 單位是字節(jié) 3145728/1024/1024=3MB  大于3M的對象直接進(jìn)入老年代

5.2.2 程序輸出(給出附加解釋)

在這里插入圖片描述

5.3 長期存活的對象應(yīng)該進(jìn)入老年代(使用-XX:MaxTenuringThreshold參數(shù)設(shè)置)

 5.3.1 設(shè)置VM Options

-XX:+PrintGCDetails             //打印GC日志
-Xms20M                              //初始堆大小為20M
-Xmx20M        //最大堆大小為20M
-Xmn10M           //年輕代大小為10M,則老年代大小=堆大小20M-年輕代大小10M=10M
-XX:SurvivorRatio=8     //年輕代 Eden:Survivor=8  則Eden為8M  Survivor0為1M  Survivor1為1M
-XX:+UseSerialGC       //筆者使用的jdk8默認(rèn)為Parallel scavenge+Parallel old收集器組合,書上使用Serial+Serial Old的收集器組合,這里設(shè)置好
-XX:MaxTenuringThreshold=1   //表示經(jīng)歷一次Minor GC,就到老年代中去

5.3.2 程序輸出(給出附加解釋)

第一步驟:只分配allocation1 allocation2,不會產(chǎn)生任何Minor GC,對象都在Eden區(qū)中

在這里插入圖片描述

第二步驟:分配allocation3,產(chǎn)生Minor GC,allocation2移入老年區(qū)

在這里插入圖片描述

第三步驟:allocation3再次分配,allocation1也被送入老年區(qū),老年區(qū)里有allocation1 allocation2

在這里插入圖片描述

六、尾聲

本文講述JVM自動內(nèi)存管理(包括內(nèi)存回收和內(nèi)存),前言部分從操作系統(tǒng)引入JVM,第二部分介紹JVM空間結(jié)構(gòu)(運(yùn)行時數(shù)據(jù)區(qū)、堆內(nèi)存和非堆內(nèi)存),第三部分介紹HotSpot虛擬機(jī),第四部分和第五部分分別介紹自動內(nèi)存回收和自動內(nèi)存分配的原理實(shí)現(xiàn)。

到此這篇關(guān)于深入理解JVM自動內(nèi)存管理的文章就介紹到這了,更多相關(guān)JVM自動內(nèi)存管理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java 5個人坐在一起(有關(guān)第五個人歲數(shù)的問題)

    Java 5個人坐在一起(有關(guān)第五個人歲數(shù)的問題)

    利用遞歸的方法,遞歸分為回推和遞推兩個階段。要想知道第五個人歲數(shù),需知道第四人的歲數(shù),依次類推,推到第一人(10歲),再往回推,需要的朋友可以參考下
    2017-02-02
  • spring boot實(shí)現(xiàn)文件上傳

    spring boot實(shí)現(xiàn)文件上傳

    這篇文章主要為大家詳細(xì)介紹了spring boot實(shí)現(xiàn)文件上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • 簡單了解java局部變量與成員變量的區(qū)別

    簡單了解java局部變量與成員變量的區(qū)別

    這篇文章主要介紹了簡單了解java局部變量與成員變量的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • ssm框架Springmvc文件上傳實(shí)現(xiàn)代碼詳解

    ssm框架Springmvc文件上傳實(shí)現(xiàn)代碼詳解

    這篇文章主要介紹了ssm框架Springmvc文件上傳實(shí)現(xiàn)代碼詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • SpringMVC中的@ControllerAdvice使用場景詳解

    SpringMVC中的@ControllerAdvice使用場景詳解

    這篇文章主要介紹了SpringMVC中的@ControllerAdvice使用場景詳解,在Spring?MVC進(jìn)行調(diào)用的過程中,會有很多的特殊的需求,比如全局異常,分頁信息和分頁搜索條件,請求時帶來返回時還得回顯頁面,需要的朋友可以參考下
    2024-01-01
  • Jenkins集成SonarQube的方法詳解

    Jenkins集成SonarQube的方法詳解

    這篇文章主要介紹了Jenkins集成SonarQube的方法詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • Java中反射的一個簡單使用

    Java中反射的一個簡單使用

    一直感覺Java的反射機(jī)制很強(qiáng)大,JAVA反射技術(shù)在平時我們的開發(fā)中雖然很少會用到,但在我們所使用的框架源碼中是經(jīng)常會用到的。這篇文中就給大家介紹了關(guān)于Java中反射的一個簡單使用,有需要的朋友們下面來一起看看吧。
    2016-11-11
  • Java實(shí)現(xiàn)郵件發(fā)送功能

    Java實(shí)現(xiàn)郵件發(fā)送功能

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)郵件發(fā)送功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • springboot集成Mybatis的詳細(xì)教程

    springboot集成Mybatis的詳細(xì)教程

    今天給大家?guī)淼倪€是關(guān)于springboot的相關(guān)知識,文章圍繞著springboot集成Mybatis的詳細(xì)教程展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • SpringBoot+Ajax+redis實(shí)現(xiàn)隱藏重要接口地址的方法

    SpringBoot+Ajax+redis實(shí)現(xiàn)隱藏重要接口地址的方法

    這篇文章主要介紹了SpringBoot+Ajax+redis實(shí)現(xiàn)隱藏重要接口地址,本篇文章主要講訴使用SpringBoot項目配合Ajax和redis實(shí)現(xiàn)隱藏重要接口地址,這里我以隱藏秒殺地址為例,需要的朋友可以參考下
    2024-03-03

最新評論

18禁美女羞羞免费网站| 99一区二区在线观看| 国产在线一区二区三区麻酥酥| 欧美成人精品欧美一级黄色| 1769国产精品视频免费观看| 东京干手机福利视频| 青青青青青青草国产| 99热久久极品热亚洲| 欧美精品欧美极品欧美视频| 欧美一区二区三区在线资源| 亚洲推理片免费看网站| 亚洲av无硬久久精品蜜桃| 丰满少妇人妻xxxxx| 狠狠操狠狠操免费视频| 亚洲成人免费看电影| 日本人妻欲求不满中文字幕| 男女之间激情网午夜在线| 大肉大捧一进一出好爽在线视频| 激情小视频国产在线| 欧美特级特黄a大片免费| 又色又爽又黄的美女裸体| yellow在线播放av啊啊啊| 亚洲欧美福利在线观看| 欧美黑人巨大性xxxxx猛交| 91亚洲手机在线视频播放| 98视频精品在线观看| 91福利在线视频免费观看| 偷拍自拍视频图片免费| 精品91自产拍在线观看一区| 日日操夜夜撸天天干| 亚洲福利精品福利精品福利| 在线免费91激情四射 | 97人妻无码AV碰碰视频| 97国产在线av精品| 精品久久久久久久久久中文蒉| 超碰97人人澡人人| 日本少妇人妻xxxxx18| 青青青激情在线观看视频| 少妇人妻100系列| 黑人巨大精品欧美视频| 国产男女视频在线播放| 初美沙希中文字幕在线| 中文字幕无码一区二区免费| 天天干天天爱天天色| 大香蕉大香蕉在线有码 av| 亚洲第一伊人天堂网| 绝顶痉挛大潮喷高潮无码| 日本丰满熟妇BBXBBXHD| 国产精品黄片免费在线观看| 内射久久久久综合网| 久草视频在线看免费| 国产精品黄色的av| 91国产在线视频免费观看| 一区二区在线视频中文字幕| 伊人情人综合成人久久网小说 | 久久久精品国产亚洲AV一| h国产小视频福利在线观看| 91精品国产观看免费| 好太好爽好想要免费| 97国产精品97久久| 婷婷综合蜜桃av在线| 欧美黑人巨大性xxxxx猛交| 亚洲福利午夜久久久精品电影网| 啊啊啊想要被插进去视频| 成年人中文字幕在线观看| 中文字幕第1页av一天堂网 | 人人妻人人爽人人添夜| 日本精品美女在线观看| 少妇人妻真实精品视频| 久久精品在线观看一区二区| 香蕉aⅴ一区二区三区| 五月婷婷在线观看视频免费| 欧美精品久久久久久影院| 韩国爱爱视频中文字幕| 2021天天色天天干| 亚洲第17页国产精品| 亚洲精品午夜aaa久久| 午夜久久久久久久精品熟女| 精品久久久久久久久久久99| 黄色中文字幕在线播放| 欧美美女人体视频一区| 精品区一区二区三区四区人妻 | 亚洲欧美综合在线探花| 久久麻豆亚洲精品av| 国产欧美精品免费观看视频| 天天色天天操天天透| 天堂av在线播放免费| 久久久久久性虐视频| 自拍 日韩 欧美激情| 社区自拍揄拍尻屁你懂的| 欧美日韩一级黄片免费观看| 亚洲 欧美 精品 激情 偷拍 | 日韩熟女系列一区二区三区| 黄色黄色黄片78在线| 日本精品视频不卡一二三| www天堂在线久久| 亚洲免费在线视频网站| 人妻丝袜诱惑我操她视频| 91精品国产综合久久久蜜| 亚洲国产中文字幕啊啊啊不行了| av破解版在线观看| 91人妻精品一区二区久久| 亚洲成人av在线一区二区| 免费成人av中文字幕| 丰满熟女午夜福利视频| 国产亚洲精品品视频在线| 色吉吉影音天天干天天操| 亚洲欧美清纯唯美另类| 国产精品国色综合久久| 超级碰碰在线视频免费观看| 黄色在线观看免费观看在线| 91综合久久亚洲综合| 亚洲福利精品视频在线免费观看| 欧美黑人巨大性xxxxx猛交| 一级黄色片夫妻性生活| 久久人人做人人妻人人玩精品vr| 天天躁日日躁狠狠躁av麻豆| 精品欧美一区二区vr在线观看 | 人妻丝袜诱惑我操她视频| 亚洲在线免费h观看网站| 中文字幕—97超碰网| 国产亚洲精品视频合集| 亚洲卡1卡2卡三卡四老狼| 亚洲av琪琪男人的天堂| 成人亚洲国产综合精品| 中文字幕 人妻精品| 五十路丰满人妻熟妇| 天天射夜夜操综合网| 欧美一级片免费在线成人观看 | 曰本无码人妻丰满熟妇啪啪| 日韩av熟妇在线观看| 亚洲免费国产在线日韩| 香蕉aⅴ一区二区三区| 中文字幕日韩精品就在这里| 日本少妇人妻xxxxx18| 狠狠嗨日韩综合久久| 91色九色porny| 不卡精品视频在线观看| 人妻丝袜诱惑我操她视频| 特一级特级黄色网片| 91精品视频在线观看免费| 91福利视频免费在线观看| 超pen在线观看视频公开97| 视频一区 二区 三区 综合| 亚洲推理片免费看网站| 久久尻中国美女视频| 国产黄色片蝌蚪九色91| 亚洲精品亚洲人成在线导航| 人妻素人精油按摩中出| 亚洲 中文字幕在线 日韩| 在线视频这里只有精品自拍| 水蜜桃国产一区二区三区| huangse网站在线观看| 国产av福利网址大全| 欧美中国日韩久久精品| 国产在线免费观看成人| 国产女人露脸高潮对白视频| 欧美成人综合视频一区二区| 最新国产亚洲精品中文在线| 亚洲无线观看国产高清在线| 视频一区二区综合精品| 激情啪啪啪啪一区二区三区| 中国视频一区二区三区| 久久香蕉国产免费天天| 亚洲av日韩高清hd| 香蕉91一区二区三区| 天天干夜夜操天天舔| 老司机午夜精品视频资源 | 国产麻豆精品人妻av| 91精品国产综合久久久蜜| 视频二区在线视频观看| 久久精品久久精品亚洲人| 91天堂精品一区二区| 啊慢点鸡巴太大了啊舒服视频| 亚洲国产美女一区二区三区软件| 日本熟妇一区二区x x| 亚洲成人熟妇一区二区三区 | 亚洲国产精品久久久久蜜桃| www,久久久,com| 精品乱子伦一区二区三区免费播 | 精品亚洲在线免费观看| 中文字幕一区二区三区人妻大片 | 亚洲一区二区久久久人妻| 国产精品午夜国产小视频| 亚洲精品av在线观看| 插逼视频双插洞国产操逼插洞| 国产va精品免费观看| 天天日天天玩天天摸| 五月天色婷婷在线观看视频免费| 偷拍自拍视频图片免费| 欧美乱妇无乱码一区二区| 亚洲av男人的天堂你懂的| 久久精品美女免费视频| 午夜久久久久久久精品熟女| 在线不卡成人黄色精品| 日本精品一区二区三区在线视频。| 综合色区亚洲熟妇shxstz| 亚洲成a人片777777| 97年大学生大白天操逼| 色综合久久无码中文字幕波多| 九色porny九色9l自拍视频| 激情小视频国产在线| 一区二区三区日韩久久| 国产一区自拍黄视频免费观看| av中文在线天堂精品| gogo国模私拍视频| 岛国黄色大片在线观看| 日本a级视频老女人| 偷拍自拍视频图片免费| 欧美天堂av无线av欧美| 在线免费观看黄页视频| 天天日天天干天天舔天天射| 亚洲av可乐操首页| 免费岛国喷水视频在线观看| 亚洲美女高潮喷浆视频| 97国产在线观看高清| 97超碰国语国产97超碰| 亚洲精品国产久久久久久| 中文乱理伦片在线观看| 巨乳人妻日下部加奈被邻居中出| 天天干天天啪天天舔| 欧美色呦呦最新网址| 91自产国产精品视频| 成人国产影院在线观看| 久久久极品久久蜜桃| 免费看美女脱光衣服的视频| 极品性荡少妇一区二区色欲| 91www一区二区三区| 蜜臀成人av在线播放| 极品粉嫩小泬白浆20p主播| 亚洲图库另类图片区| 啊啊好大好爽啊啊操我啊啊视频| 偷拍自拍亚洲美腿丝袜| 亚洲欧美一区二区三区电影| 老司机福利精品免费视频一区二区| 男人天堂最新地址av| 98视频精品在线观看| 在线观看黄色成年人网站| 久久尻中国美女视频| 国产三级片久久久久久久| 欧美黑人性猛交xxxxⅹooo| 中文字幕一区二区三区人妻大片| 国产精品黄色的av| 午夜精品一区二区三区4| 国产成人自拍视频播放| 亚洲日产av一区二区在线| 青青伊人一精品视频| av在线免费中文字幕| 在线观看免费视频色97| 日本成人不卡一区二区| 亚洲av琪琪男人的天堂| 国产在线自在拍91国语自产精品| 精品美女福利在线观看| 日韩不卡中文在线视频网站| 91极品大一女神正在播放| 五十路av熟女松本翔子| 色在线观看视频免费的| 精品黑人巨大在线一区| 婷婷久久久综合中文字幕| 日本韩国亚洲综合日韩欧美国产| 大陆av手机在线观看| 黄色大片男人操女人逼| 亚洲中文字幕人妻一区| 91久久综合男人天堂| 亚洲一区久久免费视频| 欧美日本国产自视大全| 9色精品视频在线观看| 日曰摸日日碰夜夜爽歪歪| 亚洲国产在线精品国偷产拍| 懂色av蜜桃a v| 天天躁日日躁狠狠躁躁欧美av| 国产成人精品午夜福利训2021| 韩国一级特黄大片做受| 亚洲国产免费av一区二区三区| 无码中文字幕波多野不卡| 男女啪啪视频免费在线观看| 亚洲欧美综合在线探花| 好了av中文字幕在线| 日本一道二三区视频久久| 精品国产成人亚洲午夜| 亚洲精品一区二区三区老狼| 人人超碰国字幕观看97| 亚洲欧美人精品高清| 午夜成午夜成年片在线观看 | 男大肉棒猛烈插女免费视频| 亚洲美女高潮喷浆视频| 亚洲精品久久综合久| 国产视频一区在线观看| 97色视频在线观看| 大胸性感美女羞爽操逼毛片| 中出中文字幕在线观看| 夜色福利视频在线观看| 亚洲熟妇x久久av久久| 人妻少妇亚洲一区二区| 视频一区 视频二区 视频| 91麻豆精品久久久久| 2012中文字幕在线高清| 欧美黑人与人妻精品| 国产精品久久久久久久女人18| 日本美女性生活一级片| 日本美女性生活一级片| 欧美亚洲中文字幕一区二区三区| 成人在线欧美日韩国产| 美女操逼免费短视频下载链接| 最新中文字幕免费视频| 亚洲高清自偷揄拍自拍| 新97超碰在线观看| 国产又粗又硬又大视频| 红桃av成人在线观看| 欧美女同性恋免费a| 日本熟妇喷水xxx| 国产精品日韩欧美一区二区| 中文字幕日韩91人妻在线| 97色视频在线观看| 成人H精品动漫在线无码播放| 国产女孩喷水在线观看| 一区二区免费高清黄色视频| 在线观看日韩激情视频| 欧美视频不卡一区四区| 国产露脸对白在线观看| 啊啊好大好爽啊啊操我啊啊视频| 啊啊好大好爽啊啊操我啊啊视频| 国产午夜激情福利小视频在线| 婷婷久久一区二区字幕网址你懂得| 欧美另类一区二区视频| 亚洲av无硬久久精品蜜桃| av男人天堂狠狠干| 欧美韩国日本国产亚洲| 中文字幕第三十八页久久| 国产福利小视频免费观看| 欧美国品一二三产区区别| 日本少妇在线视频大香蕉在线观看| 无忧传媒在线观看视频| 亚洲免费va在线播放| 午夜大尺度无码福利视频| 久精品人妻一区二区三区| 人妻另类专区欧美制服| 天天射夜夜操狠狠干| 亚洲精品三级av在线免费观看| 精品成人啪啪18免费蜜臀| 久草福利电影在线观看| 人人妻人人澡人人爽人人dvl| japanese日本熟妇另类| 中文人妻AV久久人妻水| 国产视频网站一区二区三区| 大鸡八强奸视频在线观看| 国产实拍勾搭女技师av在线| 国产三级影院在线观看| 亚洲伊人久久精品影院一美女洗澡 | v888av在线观看视频| 中文字幕在线观看国产片| 天天操天天射天天操天天天| 中文字幕 人妻精品| 中文字幕高清免费在线人妻| 日本福利午夜电影在线观看| 可以在线观看的av中文字幕| 国产+亚洲+欧美+另类| 麻豆精品成人免费视频| 在线国产中文字幕视频| 成人av中文字幕一区| av网址国产在线观看| 国产麻豆剧果冻传媒app| 国产精品福利小视频a| 日韩成人性色生活片| 夜夜嗨av蜜臀av| 久久人人做人人妻人人玩精品vr| 中文字幕日韩人妻在线三区| 性色av一区二区三区久久久| 大鸡吧插入女阴道黄色片| 一区二区三区四区视频| 97欧洲一区二区精品免费| 啪啪啪啪啪啪啪啪av| 欧美成人猛片aaaaaaa| 中文字幕在线观看国产片| 丝袜肉丝一区二区三区四区在线看| 天天日天天干天天干天天日| 自拍偷拍亚洲另类色图| 天天日天天干天天插舔舔| 亚洲丝袜老师诱惑在线观看| av天堂中文字幕最新| 久久艹在线观看视频| 久久久制服丝袜中文字幕| 欧美精品亚洲精品日韩在线| 日本性感美女写真视频| 黑人乱偷人妻中文字幕| 哥哥姐姐综合激情小说| 精品人妻伦一二三区久| 红杏久久av人妻一区| 11久久久久久久久久久| 大香蕉伊人中文字幕| 中字幕人妻熟女人妻a62v网| 51国产偷自视频在线播放| 又粗又长 明星操逼小视频| 亚洲一区二区激情在线| av乱码一区二区三区| 国产高清在线在线视频| 视频一区二区在线免费播放| 欧洲精品第一页欧洲精品亚洲| 鸡巴操逼一级黄色气| 亚洲成人三级在线播放| 日韩av有码中文字幕| 91极品新人『兔兔』精品新作| 午夜在线观看岛国av,com| 一区二区三区久久中文字幕| 亚洲成人国产综合一区| 欧美另类一区二区视频| 伊人综合免费在线视频| 中文字幕 码 在线视频| 老鸭窝在线观看一区| 亚洲成人国产综合一区| 亚洲国产在人线放午夜| 国产精品三级三级三级| 成年午夜影片国产片| 亚洲欧美国产麻豆综合| 中文字幕成人日韩欧美| 久久久久久久亚洲午夜综合福利| 久草视频中文字幕在线观看| 色综合色综合色综合色| 欧美日韩高清午夜蜜桃大香蕉| 啪啪啪18禁一区二区三区| 亚洲欧美精品综合图片小说| 亚洲变态另类色图天堂网| 绯色av蜜臀vs少妇| 国产精品亚洲在线观看| 欧美香蕉人妻精品一区二区| 亚洲狠狠婷婷综合久久app | 亚洲免费福利一区二区三区| 阴茎插到阴道里面的视频| 亚洲国产成人av在线一区| 91免费黄片可看视频| 久草视频首页在线观看| 国产精品午夜国产小视频| 91大神福利视频网| 国产成人无码精品久久久电影| www骚国产精品视频| 欧美另类重口味极品在线观看| 青草青永久在线视频18| 亚洲国产在线精品国偷产拍| 成人免费公开视频无毒 | 日韩加勒比东京热二区| 天天日天天爽天天干| 国产精品久久久久久久精品视频 | 人妻丝袜诱惑我操她视频| 青青青青青操视频在线观看| 91国产在线视频免费观看| 天天躁夜夜躁日日躁a麻豆| 亚洲熟妇无码一区二区三区| 亚洲日本一区二区三区| 欧美va不卡视频在线观看| 蜜臀av久久久久久久| 一区二区三区四区五区性感视频| 一区二区视频在线观看免费观看| 三级等保密码要求条款| 一区二区三区av高清免费| 18禁污污污app下载| 韩国亚洲欧美超一级在线播放视频 | 国产高清精品极品美女| 夫妻在线观看视频91| 久久国产精品精品美女| 曰本无码人妻丰满熟妇啪啪| 啪啪啪啪啪啪啪免费视频| 粉嫩欧美美人妻小视频| 天天色天天操天天舔| 国产精品视频资源在线播放| 欧美伊人久久大香线蕉综合| 精品国产亚洲av一淫| 天天射夜夜操狠狠干| 青青青青青青青青青青草青青| 中国产一级黄片免费视频播放| 天天草天天色天天干| 国产亚洲视频在线二区| 久久久久只精品国产三级| 亚洲图库另类图片区| 把腿张开让我插进去视频| 小泽玛利亚视频在线观看| 老司机免费视频网站在线看| 热久久只有这里有精品| 久久精品在线观看一区二区| 国产密臀av一区二区三| 91www一区二区三区| 美女大bxxxx内射| 欧美日本在线观看一区二区| 免费在线福利小视频| aiss午夜免费视频| 青青青青青免费视频| 2025年人妻中文字幕乱码在线| 黄色黄色黄片78在线| 亚洲 国产 成人 在线| 久久永久免费精品人妻专区| 在线免费观看av日韩| 蜜桃视频在线欧美一区| 青青草原网站在线观看| 东京热男人的av天堂| 欧美黑人与人妻精品| 亚洲欧美成人综合在线观看| 亚洲午夜精品小视频| 久久久噜噜噜久久熟女av| 1024久久国产精品| av中文字幕电影在线看| 亚洲av极品精品在线观看| 亚洲一级 片内射视正片| 亚洲av日韩av第一区二区三区| 天天色天天爱天天爽| 人妻无码色噜噜狠狠狠狠色| 亚洲蜜臀av一区二区三区九色| 老师让我插进去69AV| 91精品综合久久久久3d动漫| 中字幕人妻熟女人妻a62v网 | 免费看国产又粗又猛又爽又黄视频| 久草视频福利在线首页| 午夜dv内射一区区| 久久久超爽一二三av| 国产成人午夜精品福利| 视频 一区二区在线观看| 中文字幕AV在线免费看 | 11久久久久久久久久久| 中国把吊插入阴蒂的视频| 这里只有精品双飞在线播放| 免费高清自慰一区二区三区网站| 中国视频一区二区三区| 免费费一级特黄真人片| 亚洲 图片 欧美 图片| 小穴多水久久精品免费看| 国产一区av澳门在线观看| 97人人妻人人澡人人爽人人精品| 老司机免费福利视频网| 91久久综合男人天堂| 99热久久这里只有精品8| 日本真人性生活视频免费看| 91 亚洲视频在线观看| 成熟熟女国产精品一区| 亚洲熟妇x久久av久久| 日韩av大胆在线观看| 亚洲国产精品久久久久蜜桃| 99久久激情婷婷综合五月天| 涩涩的视频在线观看视频| 国产一区av澳门在线观看| 黄色片一级美女黄色片| 婷婷色中文亚洲网68| 久久久91蜜桃精品ad| 日本裸体熟妇区二区欧美| 最新黄色av网站在线观看| 2019av在线视频| 91www一区二区三区| 国产成人综合一区2区| 国产亚洲成人免费在线观看| 免费看高清av的网站| 在线国产日韩欧美视频| 亚洲福利午夜久久久精品电影网 | 51国产成人精品视频 | aiss午夜免费视频| 国产伦精品一区二区三区竹菊| 亚洲中文字幕国产日韩| 亚洲午夜电影在线观看| 521精品视频在线观看| 久久综合老鸭窝色综合久久| asmr福利视频在线观看| 国产妇女自拍区在线观看| 精品久久久久久久久久久a√国产| 午夜国产福利在线观看| aiss午夜免费视频| 中文字幕之无码色多多| 亚洲精品午夜aaa久久| 日日日日日日日日夜夜夜夜夜夜| 九色porny九色9l自拍视频| 久久综合老鸭窝色综合久久| 中文字幕一区二区三区蜜月| 日本熟妇一区二区x x| 日韩av免费观看一区| 在线观看欧美黄片一区二区三区| 天天躁夜夜躁日日躁a麻豆| 日比视频老公慢点好舒服啊| 中文字幕无码日韩专区免费| 93视频一区二区三区| 100%美女蜜桃视频| 亚洲 中文 自拍 另类 欧美| 11久久久久久久久久久| 9国产精品久久久久老师| 超级av免费观看一区二区三区| 在线免费观看99视频| 九色视频在线观看免费| 日韩欧美国产一区不卡| 黄色片一级美女黄色片| av完全免费在线观看av| 中文字幕人妻av在线观看| 国内精品在线播放第一页| 日韩美女综合中文字幕pp| 中国无遮挡白丝袜二区精品| 自拍偷拍,中文字幕| 91精品免费久久久久久| 国产精品日韩欧美一区二区| 在线免费观看国产精品黄色| 视频在线亚洲一区二区| 91精品国产高清自在线看香蕉网| 只有精品亚洲视频在线观看| 国产精品久久久久久久久福交| 色偷偷伊人大杳蕉综合网| 91久久综合男人天堂| 66久久久久久久久久久| 欧美精品资源在线观看| av老司机精品在线观看| 老师让我插进去69AV| 亚洲激情唯美亚洲激情图片| 无码精品一区二区三区人| 国产精品一区二区av国| 亚洲图库另类图片区| 夜夜骑夜夜操夜夜奸| 涩爱综合久久五月蜜臀| 99精品国产aⅴ在线观看| aiss午夜免费视频| 日本精品美女在线观看| 97人妻无码AV碰碰视频| 国产精品久久久久久久精品视频| 四川五十路熟女av| 国产 在线 免费 精品| 性感美女福利视频网站| 日韩av熟妇在线观看| 精品成人啪啪18免费蜜臀| av久久精品北条麻妃av观看| 大学生A级毛片免费视频| 亚洲一区二区久久久人妻| 五月激情婷婷久久综合网| japanese五十路熟女熟妇| 日韩精品二区一区久久| 中文 成人 在线 视频| 精品视频中文字幕在线播放| 日韩写真福利视频在线观看| 国产精品久久久黄网站| 丰满熟女午夜福利视频| 女人精品内射国产99| 国产熟妇一区二区三区av | 亚洲综合乱码一区二区| 99久久激情婷婷综合五月天| 久久久久久久99精品| 日本av高清免费网站| 欧洲国产成人精品91铁牛tv| 日韩成人免费电影二区| 九色精品视频在线播放| 午夜精品一区二区三区城中村| 美日韩在线视频免费看| 75国产综合在线视频| 天天操夜夜骑日日摸| 中文字幕 码 在线视频| 国产午夜激情福利小视频在线| 青青草原网站在线观看| 99精品亚洲av无码国产另类| 亚洲码av无色中文| 日本高清在线不卡一区二区| 日本xx片在线观看| 欧美熟妇一区二区三区仙踪林| 欧美黑人性猛交xxxxⅹooo| 精产国品久久一二三产区区别 | 午夜的视频在线观看| 男人天堂最新地址av| 很黄很污很色的午夜网站在线观看| 动色av一区二区三区| 午夜久久久久久久精品熟女| 久草电影免费在线观看| 日本黄在免费看视频| 9色精品视频在线观看| 香蕉aⅴ一区二区三区| 欧洲黄页网免费观看| 精品欧美一区二区vr在线观看 | 午夜国产免费福利av| 日本后入视频在线观看| 最近的中文字幕在线mv视频| 超碰97人人做人人爱| 久久麻豆亚洲精品av| 亚洲最大黄了色网站| 日本人妻欲求不满中文字幕| 高潮喷水在线视频观看| 阴茎插到阴道里面的视频| 久久精品国产23696| 蜜桃色婷婷久久久福利在线| 天天草天天色天天干| 日韩少妇人妻精品无码专区| 国产成人无码精品久久久电影| 国产白袜脚足J棉袜在线观看| 99精品视频在线观看免费播放 | 成人性爱在线看四区| 激情国产小视频在线| 久久久久久国产精品| 中文字幕+中文字幕| 91人妻精品一区二区久久| 天天操天天污天天射| 一个色综合男人天堂| 中字幕人妻熟女人妻a62v网| 亚洲av无码成人精品区辽| 懂色av之国产精品| 青青青青青免费视频| 国产午夜激情福利小视频在线| 加勒比视频在线免费观看| 久久久久91精品推荐99| jiuse91九色视频| 国产av一区2区3区| 毛茸茸的大外阴中国视频| 天天日天天日天天射天天干| 国产九色91在线观看精品| 亚洲在线免费h观看网站| 2018在线福利视频| 夜夜嗨av蜜臀av| 骚逼被大屌狂草视频免费看| 亚洲欧洲一区二区在线观看| 美日韩在线视频免费看| 午夜极品美女福利视频| 大陆胖女人与丈夫操b国语高清| AV天堂一区二区免费试看| 老司机在线精品福利视频| 成熟丰满熟妇高潮xx×xx| 少妇被强干到高潮视频在线观看| 极品丝袜一区二区三区| 久久一区二区三区人妻欧美| 亚洲一区自拍高清免费视频| 55夜色66夜色国产精品站| 91中文字幕免费在线观看| av资源中文字幕在线观看| 日本人妻欲求不满中文字幕| 久久精品国产999| 88成人免费av网站| 丰满的继坶3中文在线观看| 大学生A级毛片免费视频| 亚洲精品午夜久久久久| 黑人大几巴狂插日本少妇| 激情内射在线免费观看| 国产 在线 免费 精品| 首之国产AV医生和护士小芳| 偷拍3456eee| 成人久久精品一区二区三区| 亚洲美女自偷自拍11页| 老鸭窝在线观看一区| 久久久久久九九99精品| 国产中文字幕四区在线观看| 五十路息与子猛烈交尾视频| 久久精品亚洲成在人线a| 色天天天天射天天舔| 免费大片在线观看视频网站| 亚洲在线观看中文字幕av| 清纯美女在线观看国产| 99久久99一区二区三区| 亚洲码av无色中文| 大鸡巴操b视频在线| lutube在线成人免费看| 国产真实灌醉下药美女av福利| 精品人人人妻人人玩日产欧| 亚洲av成人网在线观看| 东京干手机福利视频| 日本少妇的秘密免费视频| 97青青青手机在线视频| 粗大的内捧猛烈进出爽大牛汉子| 98精产国品一二三产区区别| 美女福利视频导航网站| 天天草天天色天天干| 人妻丝袜av在线播放网址| 国产男女视频在线播放| 大鸡吧插入女阴道黄色片| 一区二区三区另类在线| 亚洲免费在线视频网站| 动漫av网站18禁| 2021最新热播中文字幕| 欧美天堂av无线av欧美| 小泽玛利亚视频在线观看| 美女视频福利免费看| 国产极品精品免费视频| 新婚人妻聚会被中出| 国产精品久久综合久久| 55夜色66夜色国产精品站| 国产内射中出在线观看| 亚洲日本一区二区三区| 久久麻豆亚洲精品av| 国产日本欧美亚洲精品视| 成人网18免费视频版国产 | 91免费黄片可看视频| 亚洲精品午夜久久久久| 国产精品午夜国产小视频| 亚洲视频在线视频看视频在线| 边摸边做超爽毛片18禁色戒| 人妻无码色噜噜狠狠狠狠色| 在线观看黄色成年人网站| 青春草视频在线免费播放| 粉嫩av蜜乳av蜜臀| 高清成人av一区三区| 91极品新人『兔兔』精品新作| 99精品国产免费久久| 午夜精品福利一区二区三区p| 亚洲高清视频在线不卡| 最近的中文字幕在线mv视频| 国产熟妇一区二区三区av| 一区二区三区久久久91| 红杏久久av人妻一区| 78色精品一区二区三区| 精品久久婷婷免费视频| 加勒比视频在线免费观看| 国产又粗又黄又硬又爽| 丝袜亚洲另类欧美变态| 青青青青视频在线播放| 99热碰碰热精品a中文| 熟女在线视频一区二区三区| 最后99天全集在线观看| 久久农村老妇乱69系列| 日韩人妻丝袜中文字幕| 中国熟女一区二区性xx| 亚洲精品ww久久久久久| 久久精品在线观看一区二区| 亚洲狠狠婷婷综合久久app| mm131美女午夜爽爽爽| 人妻丝袜精品中文字幕| 亚洲精品久久视频婷婷| 天天日天天日天天射天天干| 99视频精品全部15| 超级av免费观看一区二区三区| 91精品啪在线免费| 国产精品一区二区av国| 天天日天天爽天天爽| 国产视频在线视频播放| 亚洲最大免费在线观看| 黑人巨大的吊bdsm| 亚洲精品av在线观看| 国产91精品拍在线观看| 超碰中文字幕免费观看| 日本人妻精品久久久久久| 乱亲女秽乱长久久久| 精品国产午夜视频一区二区| 91精品国产综合久久久蜜| 一个色综合男人天堂| 国内自拍第一页在线观看| 天天插天天狠天天操| 扒开腿挺进肉嫩小18禁视频| 男人操女人的逼免费视频| 国产精品伦理片一区二区| 2020韩国午夜女主播在线| 亚洲日本一区二区三区 | 国产污污污污网站在线| 不卡一区一区三区在线| 国产乱子伦精品视频潮优女| 日本又色又爽又黄又粗| 国产福利小视频二区| 岛国毛片视频免费在线观看| 国产黄网站在线观看播放| 久草电影免费在线观看| 国产一区av澳门在线观看| 精产国品久久一二三产区区别| 亚洲av人人澡人人爽人人爱 | 2012中文字幕在线高清| 九一传媒制片厂视频在线免费观看| 晚上一个人看操B片| 亚洲精品麻豆免费在线观看| 日本一二三中文字幕| 天天日天天天天天天天天天天| 啊啊好慢点插舔我逼啊啊啊视频| 人妻爱爱 中文字幕| 青青在线视频性感少妇和隔壁黑丝 | 91麻豆精品传媒国产黄色片| 蜜桃视频入口久久久| 国产janese在线播放| 91国内精品自线在拍白富美| 在线免费观看99视频| 日韩美女搞黄视频免费| 日韩近亲视频在线观看| 在线不卡成人黄色精品| av视屏免费在线播放| 2018在线福利视频| 亚洲女人的天堂av| 直接观看免费黄网站| 日本一区二区三区免费小视频| 亚洲激情偷拍一区二区| 国产熟妇一区二区三区av| 成年人黄色片免费网站| 中文乱理伦片在线观看| 免费无码人妻日韩精品一区二区| 好吊视频—区二区三区| 国产麻豆国语对白露脸剧情 | 99久久久无码国产精品性出奶水| 人妻素人精油按摩中出| 一级黄片久久久久久久久| 超黄超污网站在线观看| 人妻无码色噜噜狠狠狠狠色| 热思思国产99re| 福利一二三在线视频观看| 中文字母永久播放1区2区3区| 国产chinesehd精品麻豆| 国产亚洲视频在线二区| 午夜精品一区二区三区4| 插逼视频双插洞国产操逼插洞| 天天日天天鲁天天操| 国产之丝袜脚在线一区二区三区| 欧美亚洲自偷自拍 在线| av日韩在线免费播放| 亚洲免费成人a v| 亚洲天堂av最新网址| caoporm超碰国产| gogo国模私拍视频| 欧美黄色录像免费看的| 老司机你懂得福利视频| 亚洲卡1卡2卡三卡四老狼| 一区二区三区日本伦理| 亚洲欧美一卡二卡三卡| 亚洲精品午夜久久久久| 中文字幕av第1页中文字幕| 色在线观看视频免费的| 亚洲1卡2卡三卡4卡在线观看| 国产成人无码精品久久久电影| 天天想要天天操天天干| 免费69视频在线看| 亚洲国产在人线放午夜| 91免费观看国产免费| 久久久噜噜噜久久熟女av| 91精品视频在线观看免费| 国产又粗又猛又爽又黄的视频美国| 美女骚逼日出水来了| 日本av高清免费网站| 亚洲中文字幕人妻一区| 国产日韩一区二区在线看| 丰满少妇人妻xxxxx| 日本美女成人在线视频| 综合精品久久久久97| 综合页自拍视频在线播放| 午夜免费观看精品视频| 激情图片日韩欧美人妻| 二区中出在线观看老师| 亚洲1卡2卡三卡4卡在线观看| 涩涩的视频在线观看视频| 精品国产污污免费网站入口自| 国产麻豆剧果冻传媒app| 最近中文2019年在线看| aaa久久久久久久久| 姐姐的朋友2在线观看中文字幕 | 男女之间激情网午夜在线| 国产精品精品精品999| 午夜久久久久久久精品熟女| 国产妇女自拍区在线观看| 日本一本午夜在线播放| avjpm亚洲伊人久久| 大陆胖女人与丈夫操b国语高清| yy96视频在线观看| 激情小视频国产在线| 日韩精品中文字幕在线| 2022天天干天天操| eeuss鲁片一区二区三区| 日韩av有码中文字幕| 快插进小逼里大鸡吧视频| 日日摸夜夜添夜夜添毛片性色av| 亚洲成高清a人片在线观看| 精内国产乱码久久久久久| 精品av久久久久久久| 久草视频在线看免费| 97小视频人妻一区二区| 青青草人人妻人人妻| 天天日夜夜操天天摸| 国产欧美精品一区二区高清 | 伊人综合aⅴ在线网| 日韩国产乱码中文字幕| 亚洲精品ww久久久久久| 青青青青爽手机在线| 搡老熟女一区二区在线观看| 3337p日本欧洲大胆色噜噜| 国产妇女自拍区在线观看| 亚洲欧美人精品高清| 精品美女福利在线观看| 美女小视频网站在线| 亚洲精品午夜久久久久| 最后99天全集在线观看| 韩国三级aaaaa高清视频| 美女福利写真在线观看视频| 人人妻人人澡人人爽人人dvl| 六月婷婷激情一区二区三区| 成人免费公开视频无毒| 欧美xxx成人在线| 日本av高清免费网站| 风流唐伯虎电视剧在线观看| av新中文天堂在线网址| 99的爱精品免费视频| 亚洲va国产va欧美va在线| 最新91精品视频在线| 日韩av免费观看一区| 日韩写真福利视频在线观看| 欧美黑人与人妻精品| 丝袜亚洲另类欧美变态| 日韩中文字幕精品淫| 97年大学生大白天操逼| 欧美日韩人妻久久精品高清国产| 九色精品视频在线播放| 中文字幕在线免费第一页| av新中文天堂在线网址| 91九色porny蝌蚪国产成人| 国产使劲操在线播放| 日本韩国免费一区二区三区视频 | 不卡精品视频在线观看| 午夜婷婷在线观看视频| av手机在线免费观看日韩av| 亚洲一区二区三区uij| 午夜美女福利小视频| 91超碰青青中文字幕| 亚洲黄色av网站免费播放| 99精品一区二区三区的区| 无码日韩人妻精品久久| 亚洲男人的天堂a在线| 香港一级特黄大片在线播放| 日韩欧美亚洲熟女人妻| 在线观看操大逼视频| 美女操逼免费短视频下载链接| 日韩欧美高清免费在线| 喷水视频在线观看这里只有精品| 蜜桃视频在线欧美一区| 一区二区在线视频中文字幕| 香港一级特黄大片在线播放| 国产精品视频欧美一区二区| 精品高跟鞋丝袜一区二区| 青青草人人妻人人妻| gav成人免费播放| 久久久久久久亚洲午夜综合福利| 国产精品自偷自拍啪啪啪| 婷婷五月亚洲综合在线| av一本二本在线观看| 午夜毛片不卡免费观看视频 | 国产精品黄片免费在线观看| 亚洲推理片免费看网站| 日本韩国免费福利精品| 中文字幕高清资源站| 亚洲精品乱码久久久久久密桃明| 精品久久久久久久久久久a√国产| 亚洲欧美激情国产综合久久久| 91人妻人人做人人爽在线| 久草视频中文字幕在线观看| 免费手机黄页网址大全| 亚洲女人的天堂av| 99热久久极品热亚洲| 日韩加勒比东京热二区| 适合午夜一个人看的视频| 夜色撩人久久7777| 色狠狠av线不卡香蕉一区二区| 五月天久久激情视频| 在线视频精品你懂的| 一区二区三区av高清免费| 成人亚洲精品国产精品 | 一区二区三区四区视频| 亚洲av无码成人精品区辽| 在线观看911精品国产| 好吊操视频这里只有精品| 2018在线福利视频| 中文字幕亚洲中文字幕| 久久久久国产成人精品亚洲午夜| 狠狠的往里顶撞h百合| 日本特级片中文字幕| 五十路人妻熟女av一区二区| 丰满少妇人妻xxxxx| 日本三极片中文字幕| 91天堂天天日天天操| 精品一区二区三区欧美| 在线视频精品你懂的| 少妇高潮无套内谢麻豆| 国产大学生援交正在播放| av中文字幕网址在线| 国产精品一二三不卡带免费视频| av破解版在线观看| 日本后入视频在线观看| 97精品成人一区二区三区| 亚洲欧美综合在线探花| 亚洲第一黄色在线观看| 国产性感美女福利视频| 在线不卡日韩视频播放| 2021久久免费视频| 午夜精品福利一区二区三区p | 2019av在线视频| 一区二区视频视频视频| 国产精品人妻66p| 日本在线一区二区不卡视频| 一级黄片大鸡巴插入美女| 精品亚洲中文字幕av| 亚洲国产第一页在线观看| 久久久91蜜桃精品ad| 97青青青手机在线视频 | 狠狠操操操操操操操操操| 中文字幕视频一区二区在线观看 | 边摸边做超爽毛片18禁色戒 | 999九九久久久精品| 操操网操操伊剧情片中文字幕网| 亚洲一区二区久久久人妻| 青青青国产片免费观看视频| 亚洲美女美妇久久字幕组| 91桃色成人网络在线观看| 日韩欧美一级精品在线观看| 成人免费毛片aaaa| 国产成人午夜精品福利| 黄色资源视频网站日韩| 亚洲av日韩av网站| 成人18禁网站在线播放| 国产一区二区三免费视频| 亚洲区美熟妇久久久久| 成人综合亚洲欧美一区 | 五月天中文字幕内射| 人妻无码中文字幕专区| 亚洲第一伊人天堂网| 成人网18免费视频版国产| 免费大片在线观看视频网站| 日本www中文字幕| 久草视频 久草视频2| 爱有来生高清在线中文字幕| 国产一区成人在线观看视频| 国产亚洲国产av网站在线| 国产日韩精品电影7777| 淫秽激情视频免费观看| 欧美3p在线观看一区二区三区| 亚洲女人的天堂av| 传媒在线播放国产精品一区| 超碰97人人做人人爱| 加勒比视频在线免费观看| 九九视频在线精品播放| 91国内视频在线观看| 午夜青青草原网在线观看| 99热久久这里只有精品| 免费观看理论片完整版| 夫妻在线观看视频91| 日韩特级黄片高清在线看| 又色又爽又黄的美女裸体| 天天日天天干天天搡| 偷拍自拍国产在线视频| 亚洲一区制服丝袜美腿| av中文字幕国产在线观看| 亚洲成a人片777777| 久草视频福利在线首页| 热99re69精品8在线播放| 超pen在线观看视频公开97| 黄色av网站免费在线| 中文字幕高清资源站| 人妻少妇亚洲精品中文字幕| 水蜜桃一区二区三区在线观看视频| 成人国产小视频在线观看| 日韩欧美国产一区ab| 国产男女视频在线播放| 果冻传媒av一区二区三区| 青青青青青青青青青国产精品视频| 成人av天堂丝袜在线观看| av完全免费在线观看av| 啊啊啊视频试看人妻| 97成人免费在线观看网站| 任你操任你干精品在线视频| 精品久久久久久高潮| 粉嫩小穴流水视频在线观看| 人妻另类专区欧美制服| 久久www免费人成一看片| 一区二区麻豆传媒黄片| 亚洲 中文 自拍 无码| 99re久久这里都是精品视频| 亚洲免费va在线播放| 综合色区亚洲熟妇shxstz| 少妇人妻真实精品视频| 大学生A级毛片免费视频| 国产内射中出在线观看| 中文字幕高清在线免费播放| 国产视频精品资源网站| 视频在线免费观看你懂得| 欧美视频中文一区二区三区| 深夜男人福利在线观看| 岛国黄色大片在线观看| 2020av天堂网在线观看| 中国熟女@视频91| 国产之丝袜脚在线一区二区三区| 欧美日韩高清午夜蜜桃大香蕉| 成人国产小视频在线观看| 欧美在线精品一区二区三区视频| 最新激情中文字幕视频| 日韩美女综合中文字幕pp| 青娱乐极品视频青青草| 二区中出在线观看老师| 久久艹在线观看视频| 超pen在线观看视频公开97| 精品人人人妻人人玩日产欧| 国产极品美女久久久久久| 黄色中文字幕在线播放| 亚洲狠狠婷婷综合久久app| 欧美黄色录像免费看的| 色呦呦视频在线观看视频| 欧美亚洲一二三区蜜臀| 亚洲精品 欧美日韩| 国产白袜脚足J棉袜在线观看| 欧美特色aaa大片| 韩国一级特黄大片做受| 97精品综合久久在线| 9国产精品久久久久老师| 亚洲欧美一区二区三区电影| 精品欧美一区二区vr在线观看| 日韩无码国产精品强奸乱伦| 国产美女一区在线观看| 国产九色91在线视频| 国产高清在线观看1区2区| 亚洲 欧美 自拍 偷拍 在线| 亚洲麻豆一区二区三区| 青青青艹视频在线观看| 狠狠躁夜夜躁人人爽天天久天啪| 2017亚洲男人天堂| 三级等保密码要求条款| 欧美一区二区三区高清不卡tv| 亚洲av色香蕉一区二区三区| 99一区二区在线观看| 做爰视频毛片下载蜜桃视频1| 中文字幕av男人天堂| 蜜臀av久久久久久久| 蜜桃精品久久久一区二区| 国产亚洲欧美另类在线观看| 国产精品中文av在线播放 | 2021最新热播中文字幕| 国产又粗又硬又大视频| 天天日天天添天天爽| 免费av岛国天堂网站| 亚洲国产中文字幕啊啊啊不行了| 大香蕉日本伊人中文在线| 97欧洲一区二区精品免费| 我想看操逼黄色大片| 亚洲最大黄了色网站| 亚洲国产40页第21页| 天天干狠狠干天天操| 一区二区三区麻豆福利视频| 制丝袜业一区二区三区| 夏目彩春在线中文字幕| 中文字幕亚洲久久久| 超碰97人人澡人人| 亚洲av香蕉一区区二区三区犇| 四虎永久在线精品免费区二区| 一区二区三区麻豆福利视频| 久草福利电影在线观看| 伊人情人综合成人久久网小说| 天天日天天天天天天天天天天| 午夜久久香蕉电影网| 国产精品国产三级麻豆| 国产卡一卡二卡三乱码手机| 国产之丝袜脚在线一区二区三区| 天天操夜夜骑日日摸| av欧美网站在线观看| 中文字幕1卡1区2区3区| 91免费观看在线网站| 2022天天干天天操| 中文字幕高清资源站| 欧美黑人与人妻精品| 天天日天天添天天爽| 日韩a级黄色小视频| 日韩欧美制服诱惑一区在线| 4个黑人操素人视频网站精品91| 亚洲一区二区人妻av| 亚洲成人av一区久久| 一区二区三区久久中文字幕| 视频 一区二区在线观看| 99精品亚洲av无码国产另类| 亚洲1区2区3区精华液| 伊人成人在线综合网| 青青青青草手机在线视频免费看| 午夜久久久久久久99| 日本精品一区二区三区在线视频。 | 欧美区一区二区三视频| 啊啊好大好爽啊啊操我啊啊视频| 天天做天天干天天舔| av中文字幕福利网| 十八禁在线观看地址免费 | 啊用力插好舒服视频| 首之国产AV医生和护士小芳| 自拍偷拍日韩欧美一区二区| 国产露脸对白在线观看| 91精品国产黑色丝袜| 最新欧美一二三视频| 欧美香蕉人妻精品一区二区| 精品一区二区三区在线观看| 99热久久这里只有精品| 欧美日韩不卡一区不区二区| 日本裸体熟妇区二区欧美| 中文字幕 亚洲av| 欧美黄片精彩在线免费观看| 日韩美女搞黄视频免费| 97小视频人妻一区二区| 一二三区在线观看视频| 免费在线看的黄网站| 精品91高清在线观看| 硬鸡巴动态操女人逼视频| 国产一区二区欧美三区| 99久久99一区二区三区| 青青擦在线视频国产在线| 欧美日韩中文字幕欧美| 亚洲色偷偷综合亚洲AV伊人| 国产欧美精品一区二区高清| 亚洲 自拍 色综合图| 可以免费看的www视频你懂的| 97超碰最新免费在线观看| 无套猛戳丰满少妇人妻| 1000部国产精品成人观看视频| 中文字幕av第1页中文字幕| 天天草天天色天天干| 孕妇奶水仑乱A级毛片免费看| 插小穴高清无码中文字幕| 国产日韩一区二区在线看| 国产久久久精品毛片| 91精品免费久久久久久| 精品人妻每日一部精品| 日本三极片视频网站观看| 欧美精品 日韩国产| 97精品视频在线观看| 成人30分钟免费视频| 日韩不卡中文在线视频网站| 亚洲中文字幕校园春色| 沈阳熟妇28厘米大战黑人| 亚洲欧美国产综合777| 性欧美日本大妈母与子| av网站色偷偷婷婷网男人的天堂| 午夜美女少妇福利视频| 日韩人妻xxxxx| 欧美中文字幕一区最新网址| 一区二区久久成人网| 78色精品一区二区三区| 免费观看理论片完整版| wwwxxx一级黄色片| 久久一区二区三区人妻欧美| 亚洲 国产 成人 在线| 亚洲伊人av天堂有码在线| 自拍偷拍日韩欧美一区二区| 日韩激情文学在线视频| 后入美女人妻高清在线| 亚洲欧美综合在线探花| 97少妇精品在线观看| 日本三极片中文字幕| 天天色天天操天天舔| 一区二区三区美女毛片| 蜜桃视频在线欧美一区| 青青社区2国产视频| 国产av一区2区3区| 日本一区美女福利视频| 日本韩国免费一区二区三区视频 | 日本后入视频在线观看 | av男人天堂狠狠干| 青青青爽视频在线播放| 日本黄色特一级视频| 丝袜长腿第一页在线| 国产清纯美女al在线| 38av一区二区三区| 在线观看欧美黄片一区二区三区| 午夜精品福利一区二区三区p| av日韩在线观看大全| 日本女人一级免费片| 天天日天天鲁天天操| 国产在线拍揄自揄视频网站| 天天草天天色天天干| 视频久久久久久久人妻| av一区二区三区人妻| 婷婷六月天中文字幕| 偷拍美女一区二区三区| 亚洲av日韩高清hd| 国产极品精品免费视频| 亚洲av午夜免费观看| 久久热久久视频在线观看| 国产自拍黄片在线观看| 久草视频 久草视频2| 日本av熟女在线视频| 色婷婷六月亚洲综合香蕉| 日韩av大胆在线观看| 免费看高清av的网站| 中文字幕在线第一页成人| 青青青青视频在线播放| 精品欧美一区二区vr在线观看| 北条麻妃av在线免费观看| 在线国产中文字幕视频| 快点插进来操我逼啊视频| 3D动漫精品啪啪一区二区下载| 成人高清在线观看视频| 大尺度激情四射网站| 中文字幕一区二区三区人妻大片 | 国产janese在线播放| 久久精品国产亚洲精品166m| 久久国产精品精品美女| 在线免费观看欧美小视频| caoporn蜜桃视频| 一区二区在线观看少妇| 黄色视频成年人免费观看| 91精品视频在线观看免费| 天堂女人av一区二区| 日比视频老公慢点好舒服啊| 热思思国产99re| 国产白嫩美女一区二区| 天干天天天色天天日天天射| 欧美日韩中文字幕欧美| 欧美视频综合第一页| av在线免费中文字幕| 在线观看操大逼视频| 人妻久久久精品69系列| 国产av自拍偷拍盛宴| 亚洲图片偷拍自拍区| 欧美在线精品一区二区三区视频| 亚洲熟妇x久久av久久| 久碰精品少妇中文字幕av| 日韩三级电影华丽的外出| 亚洲 人妻 激情 中文| 91精品一区二区三区站长推荐| 天天干夜夜操啊啊啊| 亚洲中文精品人人免费| 哥哥姐姐综合激情小说| 日本少妇在线视频大香蕉在线观看 | 一区二区三区四区视频在线播放| av在线资源中文字幕| 人妻丝袜av在线播放网址| 91大屁股国产一区二区| 亚洲 欧美 自拍 偷拍 在线| 欧美亚洲自偷自拍 在线| 免费观看污视频网站| 国产精品久久久久久久女人18| 97少妇精品在线观看| 欧美精品一二三视频| 在线播放 日韩 av| 成年人啪啪视频在线观看| 亚洲av自拍天堂网| 午夜福利资源综合激情午夜福利资 | 久久麻豆亚洲精品av| 免费无毒热热热热热热久| 欧美精产国品一二三区| 中文字幕AV在线免费看 | www天堂在线久久| 精品亚洲国产中文自在线| 黄片色呦呦视频免费看| 日韩二区视频一线天婷婷五| 国产性色生活片毛片春晓精品 | 年轻的人妻被夫上司侵犯| 无码日韩人妻精品久久| 东京热男人的av天堂| 中国黄色av一级片| 99精品视频之69精品视频| 91人妻精品一区二区在线看| 日本午夜爽爽爽爽爽视频在线观看| 99视频精品全部15| 成人24小时免费视频| yy96视频在线观看| 青青草在观免费国产精品| 中文字幕人妻一区二区视频| 亚洲av一妻不如妾| 天天躁日日躁狠狠躁躁欧美av| 亚洲成人熟妇一区二区三区 | 青青色国产视频在线| 这里只有精品双飞在线播放| 国产午夜男女爽爽爽爽爽视频| av亚洲中文天堂字幕网| 日本高清撒尿pissing| 91www一区二区三区| xxx日本hd高清| 天堂资源网av中文字幕| 亚洲国产免费av一区二区三区| 99久久99久国产黄毛片| 亚洲高清自偷揄拍自拍| 中文字幕人妻被公上司喝醉在线| 国产精品福利小视频a| 亚洲一级av大片免费观看| 午夜精品在线视频一区| 天码人妻一区二区三区在线看| 国产品国产三级国产普通话三级| 亚洲欧美在线视频第一页| 久草视频在线一区二区三区资源站 | 青青青青操在线观看免费| 欧洲亚洲欧美日韩综合| 精品黑人巨大在线一区| 亚洲自拍偷拍综合色| 美女吃鸡巴操逼高潮视频| 经典国语激情内射视频| 中出中文字幕在线观看| 欧美成人综合视频一区二区 | 3D动漫精品啪啪一区二区下载| 99精品国产自在现线观看| 首之国产AV医生和护士小芳| 天天夜天天日天天日| 天天干天天爱天天色| 班长撕开乳罩揉我胸好爽| 天天日天天日天天射天天干| 中国视频一区二区三区| 欧洲黄页网免费观看| 成人在线欧美日韩国产| 蝴蝶伊人久久中文娱乐网| 在线国产日韩欧美视频| 综合激情网激情五月天| 亚洲欧美久久久久久久久| 成年人该看的视频黄免费| 国产自拍在线观看成人| 日本少妇精品免费视频| 国产精品成人xxxx| 丝袜肉丝一区二区三区四区在线 | 伊人开心婷婷国产av| 日本阿v视频在线免费观看| 又粗又长 明星操逼小视频| 99热99这里精品6国产| 视频一区 二区 三区 综合| 五十路老熟女码av| 在线视频这里只有精品自拍| 啪啪啪18禁一区二区三区| 把腿张开让我插进去视频| 男人天堂色男人av| 中国无遮挡白丝袜二区精品| 黑人进入丰满少妇视频| 亚洲成人情色电影在线观看| 青青社区2国产视频| 欧美日韩中文字幕欧美| 91桃色成人网络在线观看| 国产亚洲视频在线二区| 男女啪啪视频免费在线观看| 亚洲伊人久久精品影院一美女洗澡| 大鸡巴插入美女黑黑的阴毛| 操人妻嗷嗷叫视频一区二区| 蜜桃视频17c在线一区二区| 91精品国产麻豆国产| 熟女91pooyn熟女| 精品乱子伦一区二区三区免费播| 孕妇奶水仑乱A级毛片免费看| 都市家庭人妻激情自拍视频| 亚洲精品国品乱码久久久久| 中文字幕免费在线免费| 国产精品一区二区久久久av| 亚洲综合在线观看免费| 57pao国产一区二区| 国产麻豆国语对白露脸剧情 | 99热色原网这里只有精品| 不卡一不卡二不卡三| av乱码一区二区三区| 午夜的视频在线观看| 亚洲人妻30pwc| 中文字幕日韩精品日本| 精品美女在线观看视频在线观看| 美味人妻2在线播放| 播放日本一区二区三区电影| 成人蜜臀午夜久久一区| nagger可以指黑人吗| 91在线免费观看成人| 在线网站你懂得老司机| 蜜桃视频入口久久久| 大鸡八强奸视频在线观看| 亚洲视频乱码在线观看| 日韩精品电影亚洲一区| 亚洲精品成人网久久久久久小说 | 自拍偷拍一区二区三区图片| 黄色片黄色片wyaa| 熟女91pooyn熟女| 97精品视频在线观看| 国产黄色片蝌蚪九色91| 综合激情网激情五月五月婷婷| 老鸭窝日韩精品视频观看| 欧美成人精品欧美一级黄色| 天天干天天搞天天摸| av俺也去在线播放| 中文字幕一区二区人妻电影冢本| 中文字幕亚洲中文字幕| 午夜在线观看一区视频| 午夜精品久久久久久99热| 国产成人精品午夜福利训2021| 做爰视频毛片下载蜜桃视频1| 国产视频精品资源网站| 免费人成黄页网站在线观看国产 | 日视频免费在线观看| 日韩a级精品一区二区| 国产妇女自拍区在线观看| av中文在线天堂精品| 抽查舔水白紧大视频| 大陆av手机在线观看| 伊人情人综合成人久久网小说| 亚洲av男人的天堂你懂的| 欧美亚洲自偷自拍 在线| 日韩a级黄色小视频| 姐姐的朋友2在线观看中文字幕| 青青青国产片免费观看视频| 大香蕉福利在线观看| chinese国产盗摄一区二区 | 国产av国片精品一区二区| 国产午夜男女爽爽爽爽爽视频| 中文字幕国产专区欧美激情| 极品丝袜一区二区三区| 久久人人做人人妻人人玩精品vr| 久久这里只有精品热视频| 欧美中国日韩久久精品| 日韩中文字幕福利av| 521精品视频在线观看| 丝袜国产专区在线观看| 啪啪啪18禁一区二区三区| 9久在线视频只有精品| 男人天堂色男人av| 硬鸡巴动态操女人逼视频| 亚洲图片偷拍自拍区| 绝色少妇高潮3在线观看| 色吉吉影音天天干天天操| 精品一区二区三区午夜| 欧美一级片免费在线成人观看| 亚洲一区二区三区久久午夜| 亚洲高清国产一区二区三区| 国产九色91在线视频| 漂亮 人妻被中出中文| 91久久国产成人免费网站| 国产视频在线视频播放| 在线观看成人国产电影| 三上悠亚和黑人665番号| 欧美日韩人妻久久精品高清国产| 精品久久久久久久久久久99| 亚洲青青操骚货在线视频| 粉嫩欧美美人妻小视频| 精品美女久久久久久| 久久热久久视频在线观看| 青青青视频自偷自拍38碰| 抽查舔水白紧大视频| 视频啪啪啪免费观看| gav成人免费播放| 男人的网址你懂的亚洲欧洲av| 中文字幕第1页av一天堂网| 性色蜜臀av一区二区三区| 人妻凌辱欧美丰满熟妇| 日韩在线视频观看有码在线| 天堂va蜜桃一区入口| 亚洲一区二区三区五区 | 黄色成年网站午夜在线观看| 成人高清在线观看视频| 国产精品自拍在线视频| 亚洲 欧美 自拍 偷拍 在线| 孕妇奶水仑乱A级毛片免费看| 97超碰国语国产97超碰| 国产露脸对白在线观看| 亚洲熟女综合色一区二区三区四区| 懂色av之国产精品| 亚洲欧美综合另类13p| 92福利视频午夜1000看 | 看一级特黄a大片日本片黑人| 色花堂在线av中文字幕九九| 国产视频一区在线观看| 中国视频一区二区三区| 日韩欧美国产精品91| 欧美视频一区免费在线| 女生被男生插的视频网站| 久久久精品精品视频视频| 日日日日日日日日夜夜夜夜夜夜| 非洲黑人一级特黄片| 青青青青操在线观看免费| 91精品综合久久久久3d动漫| 久久久久久久99精品| 国产精品熟女久久久久浪潮| 久久久久久97三级| 中文字幕av一区在线观看| 在线不卡成人黄色精品| 色哟哟国产精品入口| 直接能看的国产av| 国产高清97在线观看视频| 日本午夜福利免费视频| 欧美亚洲牲夜夜综合久久| 女同性ⅹxx女同hd| 福利国产视频在线观看| 天天日天天日天天射天天干| 亚洲1区2区3区精华液| 亚洲特黄aaaa片| 亚洲av自拍偷拍综合| 亚洲一区二区三区精品视频在线| 亚洲午夜在线视频福利| 亚洲国产成人av在线一区| 日韩精品中文字幕播放| 一区二区三区麻豆福利视频| 99精品国产自在现线观看| 国产成人自拍视频在线免费观看| 丝袜长腿第一页在线| 偷拍自拍福利视频在线观看| 欧美精产国品一二三产品价格| 天天躁日日躁狠狠躁躁欧美av| 国产午夜激情福利小视频在线| weyvv5国产成人精品的视频| 精品av国产一区二区三区四区| 亚洲熟妇久久无码精品| 青青草精品在线视频观看| 中文字幕一区二区自拍| 一区二区三区美女毛片| 久久久精品欧洲亚洲av| 国产黄色片在线收看| 91精品国产高清自在线看香蕉网| 阴茎插到阴道里面的视频| 亚洲区美熟妇久久久久| 老司机免费福利视频网| 综合页自拍视频在线播放| 久久久久久性虐视频| 热99re69精品8在线播放| 午夜在线观看一区视频| 午夜福利人人妻人人澡人人爽| 亚洲免费在线视频网站| 国产精品女邻居小骚货| 日本啪啪啪啪啪啪啪| 国产高清女主播在线| 亚洲午夜精品小视频| 午夜蜜桃一区二区三区| 骚逼被大屌狂草视频免费看| 99久久99一区二区三区| 亚洲一区二区三区精品乱码| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 成人亚洲国产综合精品| 黑人变态深video特大巨大| 大尺度激情四射网站| 91大屁股国产一区二区| 狍和女人的王色毛片| 丰满的继坶3中文在线观看| 狠狠鲁狠狠操天天晚上干干| 精品乱子伦一区二区三区免费播| 中国黄片视频一区91| 精品高潮呻吟久久av| 久久久91蜜桃精品ad| 夜夜操,天天操,狠狠操| 精品一区二区三区三区色爱| 欲乱人妻少妇在线视频裸| 视频在线免费观看你懂得| 亚洲午夜电影之麻豆| 一区二区三区美女毛片| 91精品国产高清自在线看香蕉网| 人人人妻人人澡人人| 九九热99视频在线观看97| 99久久成人日韩欧美精品| 91 亚洲视频在线观看| 色秀欧美视频第一页| 国产清纯美女al在线| 午夜精品在线视频一区| 中文人妻AV久久人妻水| 蜜桃视频17c在线一区二区| 亚洲精品国产久久久久久| 爱爱免费在线观看视频| 伊人成人在线综合网| 91麻豆精品传媒国产黄色片| 女人精品内射国产99| 久草福利电影在线观看| 国产清纯美女al在线| 中文字幕一区二区人妻电影冢本| 9色精品视频在线观看| 中文字幕无码日韩专区免费| 国产日本精品久久久久久久| 91chinese在线视频| 天天综合天天综合天天网| 久草视频在线看免费| 男人插女人视频网站| 亚洲免费视频欧洲免费视频| 人人妻人人爽人人添夜| 欧美一级色视频美日韩| av在线播放国产不卡| 人妻av无码专区久久绿巨人| 视频二区在线视频观看| 日本阿v视频在线免费观看| 涩涩的视频在线观看视频| 亚洲少妇高潮免费观看| 精品久久久久久久久久久a√国产| 狠狠地躁夜夜躁日日躁| 免费岛国喷水视频在线观看| 天天日天天干天天要| 亚洲欧美一区二区三区爱爱动图| av在线免费观看亚洲天堂| 日韩黄色片在线观看网站| 亚洲综合乱码一区二区| 99久久中文字幕一本人| 3D动漫精品啪啪一区二区下载| 北条麻妃av在线免费观看| 99视频精品全部15| 亚洲精品 日韩电影| 一本久久精品一区二区| 最新日韩av传媒在线| 91she九色精品国产| 青青草视频手机免费在线观看| 国产精品伦理片一区二区| 亚洲av琪琪男人的天堂| 天天操天天污天天射| 大香蕉伊人中文字幕| 好吊视频—区二区三区| 精品国产高潮中文字幕| 日本美女成人在线视频| 亚洲综合乱码一区二区| 天天操天天干天天艹| 亚洲中文字幕人妻一区| 欧美日本在线观看一区二区 | 欧美日韩亚洲国产无线码| 欧美精品亚洲精品日韩在线| 91传媒一区二区三区| 国产男女视频在线播放| 欧美久久久久久三级网| 日本熟女精品一区二区三区| 一区国内二区日韩三区欧美| 国产污污污污网站在线| 青青青青青青青在线播放视频| 亚洲高清视频在线不卡| h国产小视频福利在线观看| 国产高清精品极品美女| 欧美中文字幕一区最新网址| 久久久久91精品推荐99| 在线播放国产黄色av| 亚洲一区二区三区精品乱码| 97色视频在线观看| 硬鸡巴动态操女人逼视频| 日韩精品二区一区久久| 一区二区三区av高清免费| 欧美黑人性猛交xxxxⅹooo| 成人在线欧美日韩国产| 馒头大胆亚洲一区二区| 玖玖一区二区在线观看| av森泽佳奈在线观看| 日本少妇在线视频大香蕉在线观看 | v888av在线观看视频| 久久久噜噜噜久久熟女av| 天天操夜夜骑日日摸| 中国无遮挡白丝袜二区精品| 热思思国产99re| 日本丰满熟妇大屁股久久| 经典国语激情内射视频| 久久久精品999精品日本| 国产亚洲精品欧洲在线观看| 无忧传媒在线观看视频| 精品久久久久久久久久久久人妻 | 国产精品女邻居小骚货| 亚洲国产欧美一区二区丝袜黑人| a v欧美一区=区三区| 2022天天干天天操| 亚洲成a人片777777| 在线免费观看靠比视频的网站| 五月天色婷婷在线观看视频免费| 密臀av一区在线观看| 激情啪啪啪啪一区二区三区| 人妻少妇性色欲欧美日韩| 亚洲变态另类色图天堂网| 一级黄色片夫妻性生活| 久久人人做人人妻人人玩精品vr| 欧美少妇性一区二区三区| 1769国产精品视频免费观看| 少妇被强干到高潮视频在线观看| 精品人妻一二三区久久| 午夜极品美女福利视频| av破解版在线观看| 日本三极片中文字幕| 成熟丰满熟妇高潮xx×xx| 国产精品久久久黄网站| 视频一区二区综合精品| 888欧美视频在线| 久久国产精品精品美女| 韩国黄色一级二级三级| av手机在线免费观看日韩av| 99视频精品全部15| 久久久久久性虐视频| 人人妻人人人操人人人爽| 99久久久无码国产精品性出奶水| 国产精品精品精品999| 日韩二区视频一线天婷婷五| 视频一区 二区 三区 综合| 白白操白白色在线免费视频| 大屁股熟女一区二区三区| 欧洲国产成人精品91铁牛tv| av在线观看网址av| 在线不卡日韩视频播放| 久久热久久视频在线观看| 在线观看国产免费麻豆| 亚洲免费av在线视频| 一区二区视频在线观看免费观看 | 97瑟瑟超碰在线香蕉| 丁香花免费在线观看中文字幕| 国内自拍第一页在线观看| 国产中文字幕四区在线观看| 亚洲 色图 偷拍 欧美| 日韩熟女系列一区二区三区| 福利午夜视频在线合集| 青青青青青免费视频| 在线观看国产免费麻豆| 国产精品久久久黄网站| 国产又大又黄免费观看| 色婷婷久久久久swag精品| 不卡精品视频在线观看| 日韩av有码一区二区三区4| 伊人开心婷婷国产av| 亚洲中文字字幕乱码| 国产一区成人在线观看视频| 2020中文字幕在线播放| 天天插天天狠天天操| 亚洲午夜伦理视频在线| 成人H精品动漫在线无码播放| 中文 成人 在线 视频| 日韩美av高清在线| 午夜毛片不卡免费观看视频| av久久精品北条麻妃av观看| 在线观看亚洲人成免费网址| 超碰97人人澡人人| 国产精品女邻居小骚货| 男人在床上插女人视频| 成人久久精品一区二区三区| 一区二区三区综合视频| 少妇人妻久久久久视频黄片| 中文字幕视频一区二区在线观看| 精品国产乱码一区二区三区乱| 女人精品内射国产99| 久草免费人妻视频在线| 国产91久久精品一区二区字幕| 亚洲精品ww久久久久久| 在线观看操大逼视频| 欧美专区日韩专区国产专区| 中文字幕 人妻精品| 国产av欧美精品高潮网站| 国产日韩精品电影7777| 欧美女同性恋免费a| 偷拍美女一区二区三区| 天天干天天日天天干天天操| 少妇系列一区二区三区视频| 五月天久久激情视频| 亚欧在线视频你懂的| 国产视频网站国产视频| av在线免费中文字幕| 中文字幕 码 在线视频| 性欧美日本大妈母与子| 80电影天堂网官网| av资源中文字幕在线观看| 国产实拍勾搭女技师av在线| 在线观看免费岛国av| 激情伦理欧美日韩中文字幕| 国产成人午夜精品福利| 欧美成人黄片一区二区三区| 毛片av在线免费看| 丝袜肉丝一区二区三区四区在线看| 中文字幕人妻被公上司喝醉在线| 狠狠地躁夜夜躁日日躁| 日韩亚洲高清在线观看| 亚洲av琪琪男人的天堂| 精品亚洲国产中文自在线| 99精品国产免费久久| 久久久噜噜噜久久熟女av| 18禁美女羞羞免费网站| 亚洲欧美成人综合视频| 少妇一区二区三区久久久| 绯色av蜜臀vs少妇| av森泽佳奈在线观看| 欧美色婷婷综合在线| 国产精品三级三级三级| 午夜精品在线视频一区| 成人精品在线观看视频| 中文字幕av一区在线观看| 含骚鸡巴玩逼逼视频| 日韩美女精品视频在线观看网站| 蜜桃视频入口久久久| 天天日夜夜干天天操| 青青青青青青青青青国产精品视频| 亚洲视频在线视频看视频在线| 97欧洲一区二区精品免费| 日本熟妇色熟妇在线观看| 精品久久久久久久久久中文蒉| 中文字幕在线免费第一页| 三级等保密码要求条款| 国产高清在线在线视频| 免费观看理论片完整版| 国产亚州色婷婷久久99精品| 一区二区三区久久久91| av成人在线观看一区| 综合激情网激情五月天| 伊人综合aⅴ在线网| 久久三久久三久久三久久| 人妻无码中文字幕专区| 天堂av在线最新版在线| 成人国产激情自拍三区| 欲乱人妻少妇在线视频裸| 一区二区三区久久久91| 男生舔女生逼逼视频| 国产精品一区二区三区蜜臀av | 日本xx片在线观看| 国产日韩av一区二区在线| 9久在线视频只有精品| av欧美网站在线观看| 一区二区三区四区中文| 日本av高清免费网站| 一级黄色片夫妻性生活| 五月天中文字幕内射| 97色视频在线观看| 中文字幕一区二区亚洲一区| 中国熟女@视频91| 自拍偷拍亚洲欧美在线视频| 欧美成人黄片一区二区三区| 天天干狠狠干天天操| 国产va在线观看精品| 亚洲一级美女啪啪啪| 欧美 亚洲 另类综合| 亚洲超碰97人人做人人爱| 综合页自拍视频在线播放| 中文字幕 码 在线视频| 91中文字幕最新合集| 日韩a级黄色小视频| 亚洲最大黄了色网站| 综合色区亚洲熟妇shxstz| 国产精品久久综合久久| 97精品综合久久在线| 97超碰人人搞人人| 日韩成人综艺在线播放| 欧美在线偷拍视频免费看| 中文字幕在线免费第一页| 2021久久免费视频| 一区二区视频在线观看免费观看| 日本18禁久久久久久| 亚洲 中文 自拍 另类 欧美| 91中文字幕最新合集| 日韩av熟妇在线观看| 最后99天全集在线观看| 日韩加勒比东京热二区| 国产黄色片在线收看| 欧美中文字幕一区最新网址| 2o22av在线视频| 亚洲护士一区二区三区| 国产欧美日韩在线观看不卡| 91破解版永久免费| 天天日天天干天天插舔舔| 久久尻中国美女视频| 日本18禁久久久久久| 国产乱子伦一二三区| 国产日韩一区二区在线看 | 国产高清精品极品美女| 日本少妇精品免费视频| 综合一区二区三区蜜臀| 欧美亚洲偷拍自拍色图| 在线观看免费av网址大全| 国产欧美日韩第三页| 黄色视频在线观看高清无码| 日韩美女福利视频网| 97小视频人妻一区二区| 91麻豆精品91久久久久同性| 黄色录像鸡巴插进去| 国产精品免费不卡av| 亚洲在线免费h观看网站| 亚洲 中文 自拍 无码| 性欧美日本大妈母与子| 精品黑人一区二区三区久久国产| 孕妇奶水仑乱A级毛片免费看| 色婷婷精品大在线观看| 视频一区 二区 三区 综合| 特大黑人巨大xxxx| 天天草天天色天天干| 成人区人妻精品一区二视频| 欧美日韩情色在线观看| 人人妻人人爽人人添夜| 91欧美在线免费观看| 清纯美女在线观看国产| 国产亚洲四十路五十路| 97国产在线观看高清| 少妇ww搡性bbb91| 可以免费看的www视频你懂的| 国产精品系列在线观看一区二区| 日本女人一级免费片| 欧美80老妇人性视频| 成年人黄视频在线观看| 亚洲在线免费h观看网站| 亚洲综合一区成人在线| 天天日天天摸天天爱| 亚洲中文字字幕乱码| 欧美viboss性丰满| 2021久久免费视频| 欧美精品激情在线最新观看视频| 中文字幕 亚洲av| 18禁精品网站久久| 狠狠的往里顶撞h百合| 中文字幕一区二区亚洲一区| 欧洲黄页网免费观看| 97少妇精品在线观看| 福利午夜视频在线观看| 欧美视频中文一区二区三区| 97超碰国语国产97超碰| 国产精品探花熟女在线观看| mm131美女午夜爽爽爽| 亚洲成人三级在线播放| 亚洲丝袜老师诱惑在线观看| 鸡巴操逼一级黄色气| 日韩精品中文字幕福利| 深田咏美亚洲一区二区| 亚洲专区激情在线观看视频| 内射久久久久综合网| 内射久久久久综合网| 熟女视频一区,二区,三区| 亚洲超碰97人人做人人爱| 午夜久久久久久久99| 亚洲av色香蕉一区二区三区| 国产又粗又黄又硬又爽| 老鸭窝在线观看一区| 2021久久免费视频| 中国黄色av一级片| 日美女屁股黄邑视频| 欧美 亚洲 另类综合| 2022精品久久久久久中文字幕| www骚国产精品视频| 福利午夜视频在线合集| 亚洲av日韩精品久久久| 91综合久久亚洲综合| 男女第一次视频在线观看| 欧美精品中文字幕久久二区| av手机在线免费观看日韩av| 国产亚洲欧美视频网站| 福利在线视频网址导航| 欧美日本国产自视大全| 亚洲午夜高清在线观看| 亚洲嫩模一区二区三区| 自拍偷拍,中文字幕| aiss午夜免费视频| 日韩视频一区二区免费观看| 亚洲国产精品久久久久蜜桃| 四川五十路熟女av| 99热久久这里只有精品8| 在线免费观看欧美小视频| 国产日韩精品一二三区久久久| 中字幕人妻熟女人妻a62v网 | 欧美国品一二三产区区别| 国产在线拍揄自揄视频网站| 欧美精品资源在线观看| 色婷婷精品大在线观看| 欲乱人妻少妇在线视频裸| 好吊视频—区二区三区| 亚洲成人激情av在线| 精品黑人一区二区三区久久国产 | 91麻豆精品久久久久| 又色又爽又黄的美女裸体| 丝袜肉丝一区二区三区四区在线看| 91在线免费观看成人| 91麻豆精品秘密入口在线观看| 亚洲Av无码国产综合色区| 男大肉棒猛烈插女免费视频 | 日日操综合成人av| 国产一区av澳门在线观看| 91免费黄片可看视频| 丝袜亚洲另类欧美变态| 欧美美女人体视频一区| 黄色资源视频网站日韩| 亚洲第一黄色在线观看| 久久国产精品精品美女| 岛国青草视频在线观看| 美女福利视频网址导航| 91快播视频在线观看| 热99re69精品8在线播放| 一区二区三区美女毛片| 337p日本大胆欧美人| 一区二区三区精品日本| 一区二区三区四区视频| 天干天天天色天天日天天射| 国产亚州色婷婷久久99精品| 亚洲国产成人在线一区| 欧美亚洲免费视频观看| 久久一区二区三区人妻欧美| 青青色国产视频在线| 亚洲码av无色中文| 欧美日韩一区二区电影在线观看 | 天天艹天天干天天操| 中文字幕人妻被公上司喝醉在线| 久草视频在线免播放| 三上悠亚和黑人665番号| 午夜dv内射一区区| 亚洲老熟妇日本老妇| 国产品国产三级国产普通话三级| 五十路丰满人妻熟妇| 91九色国产熟女一区二区| 91成人精品亚洲国产| 欧美亚洲免费视频观看| 夜色撩人久久7777| 久草极品美女视频在线观看| 亚洲av男人天堂久久| 中文字幕熟女人妻久久久| 在线成人日韩av电影| av在线播放国产不卡| 51精品视频免费在线观看| 日本裸体熟妇区二区欧美| 欧洲精品第一页欧洲精品亚洲| 女人精品内射国产99| 丝袜肉丝一区二区三区四区在线 | 亚洲中文字幕人妻一区| 少妇高潮无套内谢麻豆| 久久精品在线观看一区二区| 91在线免费观看成人| 国产va在线观看精品| 一区二区久久成人网| 欧美性感尤物人妻在线免费看| 国产一区成人在线观看视频| 日韩三级黄色片网站| 99视频精品全部15| 国产av国片精品一区二区| 大香蕉伊人国产在线| 亚洲高清国产一区二区三区| 人妻自拍视频中国大陆| 国产福利在线视频一区| av一区二区三区人妻| 91中文字幕免费在线观看| 涩爱综合久久五月蜜臀| 久久久久久国产精品| 一区二区三区另类在线| 国产精品久久久久网| 性欧美日本大妈母与子| 亚洲欧美另类自拍偷拍色图| 丝袜国产专区在线观看| 91国产资源在线视频| 91超碰青青中文字幕| 在线国产中文字幕视频| 国产在线免费观看成人| 国产91久久精品一区二区字幕| 欧美精品一区二区三区xxxx| 国产精品黄色的av| 日韩精品电影亚洲一区| 38av一区二区三区| 在线观看免费视频网| 欧美日韩人妻久久精品高清国产| 亚洲视频在线观看高清| 亚洲精品三级av在线免费观看| 制服丝袜在线人妻中文字幕| 亚洲一区二区三区av网站| 自拍偷拍日韩欧美亚洲| 国产片免费观看在线观看| 馒头大胆亚洲一区二区| 国产精品探花熟女在线观看| 亚洲高清视频在线不卡| 人妻丝袜榨强中文字幕| 加勒比视频在线免费观看| 精品一区二区三区三区88| 中文字幕 人妻精品| 丝袜长腿第一页在线| 99热色原网这里只有精品| 不卡一区一区三区在线| 青青青青青手机视频| 视频二区在线视频观看| 欧美一级色视频美日韩| 丝袜肉丝一区二区三区四区在线看| 成人国产小视频在线观看| 欧美日韩国产一区二区三区三州| 免费看美女脱光衣服的视频| av乱码一区二区三区| 欧美一区二区中文字幕电影| 欧美成人综合色在线噜噜| 欧美成人黄片一区二区三区| 国产成人午夜精品福利| 日本18禁久久久久久| 午夜福利资源综合激情午夜福利资 | 中文字幕在线一区精品| av乱码一区二区三区| 精品区一区二区三区四区人妻| 毛片av在线免费看| 亚洲 中文字幕在线 日韩| 我想看操逼黄色大片| 青青草国内在线视频精选| 在线国产精品一区二区三区| 一区国内二区日韩三区欧美| 大学生A级毛片免费视频| 日本在线一区二区不卡视频| 国产高清精品一区二区三区| 日本高清成人一区二区三区| 视频一区二区综合精品| 含骚鸡巴玩逼逼视频| 一区二区三区国产精选在线播放| 888欧美视频在线| 美女操逼免费短视频下载链接| 亚洲熟女久久久36d| 免费大片在线观看视频网站| 欧美黑人巨大性xxxxx猛交| 顶级尤物粉嫩小尤物网站| 熟女人妻在线中出观看完整版| 人妻最新视频在线免费观看| 99久久超碰人妻国产| av视网站在线观看| 久草视频在线一区二区三区资源站| 亚洲另类图片蜜臀av| 中国无遮挡白丝袜二区精品| 久久99久久99精品影院| 国产日韩精品一二三区久久久| 青青在线视频性感少妇和隔壁黑丝 | 天天干天天操天天玩天天射| 91一区精品在线观看| 97超碰人人搞人人| 啪啪啪18禁一区二区三区| 日韩亚洲高清在线观看| 国产精品久久久久国产三级试频 | 高清一区二区欧美系列| 欧美日韩精品永久免费网址| 亚洲男人让女人爽的视频| 精品一区二区亚洲欧美| 极品粉嫩小泬白浆20p主播| 久久精品在线观看一区二区| 适合午夜一个人看的视频| 黄色在线观看免费观看在线| 爆乳骚货内射骚货内射在线| 99国内精品永久免费视频| 中文字幕无码一区二区免费| 一级黄片大鸡巴插入美女| 大鸡吧插入女阴道黄色片| 粉嫩欧美美人妻小视频| 成人在线欧美日韩国产| 3337p日本欧洲大胆色噜噜| 亚洲午夜电影之麻豆| 天天日天天玩天天摸| 最新激情中文字幕视频| 2018最新中文字幕在线观看| 硬鸡巴动态操女人逼视频| 40道精品招牌菜特色| 亚洲精品乱码久久久本| 一区二区三区四区中文| 自拍偷拍日韩欧美亚洲| 激情人妻校园春色亚洲欧美| 欧美日本aⅴ免费视频| 日韩精品二区一区久久| 插逼视频双插洞国产操逼插洞| 中出中文字幕在线观看| 欧美国产亚洲中英文字幕| 18禁免费av网站| 免费看美女脱光衣服的视频| 国产精品久久久久国产三级试频| 精品久久久久久久久久久99| 天天干夜夜操啊啊啊| 日韩欧美高清免费在线| 中文字幕在线观看极品视频| 91chinese在线视频| 91自产国产精品视频| 中文字幕在线一区精品| 国产欧美精品一区二区高清| 亚洲天堂成人在线观看视频网站| 色婷婷综合激情五月免费观看| 日韩欧美高清免费在线| 在线国产精品一区二区三区| 淫秽激情视频免费观看| 国产av一区2区3区| 啪啪啪啪啪啪啪免费视频| 亚洲伊人久久精品影院一美女洗澡 | 亚洲激情偷拍一区二区| 内射久久久久综合网| 精品国产亚洲av一淫| 青青青青青青青在线播放视频| 97香蕉碰碰人妻国产樱花| 亚洲成人情色电影在线观看| 一本久久精品一区二区| 伊人网中文字幕在线视频| 福利视频一区二区三区筱慧| 中文字幕乱码人妻电影| 亚洲熟女女同志女同| 国内精品在线播放第一页| 在线免费观看亚洲精品电影| 国产黄色片蝌蚪九色91| 欧美精品一区二区三区xxxx| 国产欧美日韩在线观看不卡| 九一传媒制片厂视频在线免费观看| 成人亚洲精品国产精品| 自拍偷拍亚洲另类色图| 欧美综合婷婷欧美综合| 色秀欧美视频第一页| 国产精品国产三级国产午| 欧美区一区二区三视频| 好吊视频—区二区三区| 亚洲综合自拍视频一区| 日本人妻少妇18—xx| 国产精品黄页网站视频| 欧美一区二区三区乱码在线播放| 91久久国产成人免费网站| 天天射夜夜操综合网| 日本av高清免费网站| 欧美va不卡视频在线观看| 黄片大全在线观看观看| 人妻凌辱欧美丰满熟妇| 不卡精品视频在线观看| 神马午夜在线观看视频| 日韩欧美在线观看不卡一区二区 | 天天操天天干天天艹| 天天躁夜夜躁日日躁a麻豆| av天堂加勒比在线| 97超碰最新免费在线观看| 国产高清女主播在线| 夜夜骑夜夜操夜夜奸| 成人在线欧美日韩国产| 亚洲高清一区二区三区视频在线| 亚洲成人三级在线播放| 18禁美女无遮挡免费| 天堂av中文在线最新版| 亚洲天堂av最新网址| 在线观看免费岛国av| 欧美视频不卡一区四区| av黄色成人在线观看| 99精品国产免费久久| 国产精品sm调教视频| 熟女人妻在线中出观看完整版| 中文字幕第一页国产在线| 天天色天天操天天透| 精品人妻一二三区久久| 天码人妻一区二区三区在线看| 插逼视频双插洞国产操逼插洞| 亚洲中文精品字幕在线观看| 国产精品3p和黑人大战| 插小穴高清无码中文字幕| 日本少妇在线视频大香蕉在线观看| 人妻另类专区欧美制服| 把腿张开让我插进去视频| 97人人模人人爽人人喊| 国产综合视频在线看片| 国产成人自拍视频播放| 国产精品污污污久久| 国产亚洲成人免费在线观看| 91久久综合男人天堂| 日韩欧美国产一区ab| 亚洲熟色妇av日韩熟色妇在线 | 国产在线91观看免费观看| 国产精品午夜国产小视频| 国产亚州色婷婷久久99精品| 熟女人妻三十路四十路人妻斩| 中文字幕日本人妻中出| 久久久精品欧洲亚洲av| 蜜桃视频入口久久久| 黑人巨大的吊bdsm| 亚洲精品久久视频婷婷| 精品少妇一二三视频在线| 免费在线播放a级片| 国内自拍第一页在线观看| 北条麻妃av在线免费观看| 日本熟妇丰满厨房55| 黄色三级网站免费下载| 99久久成人日韩欧美精品| 日韩三级黄色片网站| 日韩人妻xxxxx| 最新欧美一二三视频| 男人天堂色男人av| 丝袜美腿欧美另类 中文字幕| 亚洲av色图18p| 国产福利小视频大全| 国产精品sm调教视频| 免费无码人妻日韩精品一区二区| 在线观看视频污一区| 啊啊啊想要被插进去视频| 蜜桃视频入口久久久| 免费男阳茎伸入女阳道视频| 18禁美女羞羞免费网站| 丰满少妇人妻xxxxx| 人妻久久久精品69系列| 亚洲综合在线视频可播放| 80电影天堂网官网| 黄色中文字幕在线播放| 国产视频在线视频播放| 色秀欧美视频第一页| 蜜桃视频入口久久久| 绯色av蜜臀vs少妇| 亚洲欧美色一区二区| 欧美日韩v中文在线| 精品黑人巨大在线一区| 日本www中文字幕| 国产之丝袜脚在线一区二区三区| 91精品国产综合久久久蜜| 黄色成人在线中文字幕| av视屏免费在线播放| 日韩激情文学在线视频| 不卡精品视频在线观看| 国产精品三级三级三级| 国产成人一区二区三区电影网站| 国产精品大陆在线2019不卡| 天天干夜夜操啊啊啊| 国产精品成久久久久三级蜜臀av | 一区二区三区的久久的蜜桃的视频| 亚洲一级av无码一级久久精品|