3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

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

编程问答

GCD 深入理解:第一部分

發(fā)布時間:2024/9/30 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 GCD 深入理解:第一部分 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

本文翻譯自?http://www.raywenderlich.com/60749/grand-central-dispatch-in-depth-part-1

原作者:Derek Selander

譯者:@nixzhu

雖然 GCD 已經(jīng)出現(xiàn)過一段時間了,但不是每個人都明了其主要內(nèi)容。這是可以理解的;并發(fā)一直很棘手,而 GCD 是基于 C 的 API ,它們就像一組尖銳的棱角戳進 Objective-C 的平滑世界。我們將分兩個部分的教程來深入學(xué)習(xí) GCD 。

在這兩部分的系列中,第一個部分的將解釋 GCD 是做什么的,并從許多基本的 GCD 函數(shù)中找出幾個來展示。在第二部分,你將學(xué)到幾個 GCD 提供的高級函數(shù)。

什么是 GCD

GCD 是?libdispatch?的市場名稱,而 libdispatch 作為 Apple 的一個庫,為并發(fā)代碼在多核硬件(跑 iOS 或 OS X )上執(zhí)行提供有力支持。它具有以下優(yōu)點:

  • GCD 能通過推遲昂貴計算任務(wù)并在后臺運行它們來改善你的應(yīng)用的響應(yīng)性能。
  • GCD 提供一個易于使用的并發(fā)模型而不僅僅只是鎖和線程,以幫助我們避開并發(fā)陷阱。
  • GCD 具有在常見模式(例如單例)上用更高性能的原語優(yōu)化你的代碼的潛在能力。

本教程假設(shè)你對 Block 和 GCD 有基礎(chǔ)了解。如果你對 GCD 完全陌生,先看看?iOS 上的多線程和 GCD 入門教程?學(xué)習(xí)其要領(lǐng)。

GCD 術(shù)語

要理解 GCD ,你要先熟悉與線程和并發(fā)相關(guān)的幾個概念。這兩者都可能模糊和微妙,所以在開始 GCD 之前先簡要地回顧一下它們。

Serial vs. Concurrent 串行 vs. 并發(fā)

這些術(shù)語描述當(dāng)任務(wù)相對于其它任務(wù)被執(zhí)行,任務(wù)串行執(zhí)行就是每次只有一個任務(wù)被執(zhí)行,任務(wù)并發(fā)執(zhí)行就是在同一時間可以有多個任務(wù)被執(zhí)行。

雖然這些術(shù)語被廣泛使用,本教程中你可以將任務(wù)設(shè)定為一個 Objective-C 的 Block 。不明白什么是 Block ?看看?iOS 5 教程中的如何使用 Block?。實際上,你也可以在 GCD 上使用函數(shù)指針,但在大多數(shù)場景中,這實際上更難于使用。Block 就是更加容易些!

Synchronous vs. Asynchronous 同步 vs. 異步

在 GCD 中,這些術(shù)語描述當(dāng)一個函數(shù)相對于另一個任務(wù)完成,此任務(wù)是該函數(shù)要求 GCD 執(zhí)行的。一個同步函數(shù)只在完成了它預(yù)定的任務(wù)后才返回。

一個異步函數(shù),剛好相反,會立即返回,預(yù)定的任務(wù)會完成但不會等它完成。因此,一個異步函數(shù)不會阻塞當(dāng)前線程去執(zhí)行下一個函數(shù)。

注意——當(dāng)你讀到同步函數(shù)“阻塞(Block)”當(dāng)前線程,或函數(shù)是一個“阻塞”函數(shù)或阻塞操作時,不要被搞糊涂了!動詞“阻塞”描述了函數(shù)如何影響它所在的線程而與名詞“代碼塊(Block)”沒有關(guān)系。代碼塊描述了用 Objective-C 編寫的一個匿名函數(shù),它能定義一個任務(wù)并被提交到 GCD 。

譯者注:中文不會有這個問題,“阻塞”和“代碼塊”是兩個詞。

Critical Section 臨界區(qū)

就是一段代碼不能被并發(fā)執(zhí)行,也就是,兩個線程不能同時執(zhí)行這段代碼。這很常見,因為代碼去操作一個共享資源,例如一個變量若能被并發(fā)進程訪問,那么它很可能會變質(zhì)(譯者注:它的值不再可信)。

Race Condition 競態(tài)條件

這種狀況是指基于特定序列或時機的事件的軟件系統(tǒng)以不受控制的方式運行的行為,例如程序的并發(fā)任務(wù)執(zhí)行的確切順序。競態(tài)條件可導(dǎo)致無法預(yù)測的行為,而不能通過代碼檢查立即發(fā)現(xiàn)。

Deadlock 死鎖

兩個(有時更多)東西——在大多數(shù)情況下,是線程——所謂的死鎖是指它們都卡住了,并等待對方完成或執(zhí)行其它操作。第一個不能完成是因為它在等待第二個的完成。但第二個也不能完成,因為它在等待第一個的完成。

Thread Safe 線程安全

線程安全的代碼能在多線程或并發(fā)任務(wù)中被安全的調(diào)用,而不會導(dǎo)致任何問題(數(shù)據(jù)損壞,崩潰,等)。線程不安全的代碼在某個時刻只能在一個上下文中運行。一個線程安全代碼的例子是?NSDictionary?。你可以在同一時間在多個線程中使用它而不會有問題。另一方面,NSMutableDictionary?就不是線程安全的,應(yīng)該保證一次只能有一個線程訪問它。

Context Switch 上下文切換

一個上下文切換指當(dāng)你在單個進程里切換執(zhí)行不同的線程時存儲與恢復(fù)執(zhí)行狀態(tài)的過程。這個過程在編寫多任務(wù)應(yīng)用時很普遍,但會帶來一些額外的開銷。

Concurrency vs Parallelism 并發(fā)與并行

并發(fā)和并行通常被一起提到,所以值得花些時間解釋它們之間的區(qū)別。

并發(fā)代碼的不同部分可以“同步”執(zhí)行。然而,該怎樣發(fā)生或是否發(fā)生都取決于系統(tǒng)。多核設(shè)備通過并行來同時執(zhí)行多個線程;然而,為了使單核設(shè)備也能實現(xiàn)這一點,它們必須先運行一個線程,執(zhí)行一個上下文切換,然后運行另一個線程或進程。這通常發(fā)生地足夠快以致給我們并發(fā)執(zhí)行地錯覺,如下圖所示:

雖然你可以編寫代碼在 GCD 下并發(fā)執(zhí)行,但 GCD 會決定有多少并行的需求。并行要求并發(fā),但并發(fā)并不能保證并行。

更深入的觀點是并發(fā)實際上是關(guān)于構(gòu)造。當(dāng)你在腦海中用 GCD 編寫代碼,你組織你的代碼來暴露能同時運行的多個工作片段,以及不能同時運行的那些。如果你想深入此主題,看看?這個由Rob Pike做的精彩的講座?。

Queues 隊列

GCD 提供有?dispatch queues?來處理代碼塊,這些隊列管理你提供給 GCD 的任務(wù)并用 FIFO 順序執(zhí)行這些任務(wù)。這就保證了第一個被添加到隊列里的任務(wù)會是隊列中第一個開始的任務(wù),而第二個被添加的任務(wù)將第二個開始,如此直到隊列的終點。

所有的調(diào)度隊列(dispatch queues)自身都是線程安全的,你能從多個線程并行的訪問它們。當(dāng)你了解了調(diào)度隊列如何為你自己代碼的不同部分提供線程安全后,GCD的優(yōu)點就是顯而易見的。關(guān)于這一點的關(guān)鍵是選擇正確類型的調(diào)度隊列和正確的調(diào)度函數(shù)來提交你的工作。

在本節(jié)你會看到兩種調(diào)度隊列,都是由 GCD 提供的,然后看一些描述如何用調(diào)度函數(shù)添加工作到隊列的例子。

Serial Queues 串行隊列

串行隊列中的任務(wù)一次執(zhí)行一個,每個任務(wù)只在前一個任務(wù)完成時才開始。而且,你不知道在一個 Block 結(jié)束和下一個開始之間的時間長度,如下圖所示:

這些任務(wù)的執(zhí)行時機受到 GCD 的控制;唯一能確保的事情是 GCD 一次只執(zhí)行一個任務(wù),并且按照我們添加到隊列的順序來執(zhí)行。

由于在串行隊列中不會有兩個任務(wù)并發(fā)運行,因此不會出現(xiàn)同時訪問臨界區(qū)的風(fēng)險;相對于這些任務(wù)來說,這就從競態(tài)條件下保護了臨界區(qū)。所以如果訪問臨界區(qū)的唯一方式是通過提交到調(diào)度隊列的任務(wù),那么你就不需要擔(dān)心臨界區(qū)的安全問題了。

Concurrent Queues 并發(fā)隊列

在并發(fā)隊列中的任務(wù)能得到的保證是它們會按照被添加的順序開始執(zhí)行,但這就是全部的保證了。任務(wù)可能以任意順序完成,你不會知道何時開始運行下一個任務(wù),或者任意時刻有多少 Block 在運行。再說一遍,這完全取決于 GCD 。

下圖展示了一個示例任務(wù)執(zhí)行計劃,GCD 管理著四個并發(fā)任務(wù):

注意 Block 1,2 和 3 都立馬開始運行,一個接一個。在 Block 0 開始后,Block 1等待了好一會兒才開始。同樣, Block 3 在 Block 2 之后才開始,但它先于 Block 2 完成。

何時開始一個 Block 完全取決于 GCD 。如果一個 Block 的執(zhí)行時間與另一個重疊,也是由 GCD 來決定是否將其運行在另一個不同的核心上,如果那個核心可用,否則就用上下文切換的方式來執(zhí)行不同的 Block 。

有趣的是, GCD 提供給你至少五個特定的隊列,可根據(jù)隊列類型選擇使用。

Queue Types 隊列類型

首先,系統(tǒng)提供給你一個叫做?主隊列(main queue)?的特殊隊列。和其它串行隊列一樣,這個隊列中的任務(wù)一次只能執(zhí)行一個。然而,它能保證所有的任務(wù)都在主線程執(zhí)行,而主線程是唯一可用于更新 UI 的線程。這個隊列就是用于發(fā)生消息給?UIView?或發(fā)送通知的。

系統(tǒng)同時提供給你好幾個并發(fā)隊列。它們叫做?全局調(diào)度隊列(Global Dispatch Queues)?。目前的四個全局隊列有著不同的優(yōu)先級:background、low、default?以及?high。要知道,Apple 的 API 也會使用這些隊列,所以你添加的任何任務(wù)都不會是這些隊列中唯一的任務(wù)。

最后,你也可以創(chuàng)建自己的串行隊列或并發(fā)隊列。這就是說,至少有五個隊列任你處置:主隊列、四個全局調(diào)度隊列,再加上任何你自己創(chuàng)建的隊列。

以上是調(diào)度隊列的大框架!

GCD 的“藝術(shù)”歸結(jié)為選擇合適的隊列來調(diào)度函數(shù)以提交你的工作。體驗這一點的最好方式是走一遍下邊的列子,我們沿途會提供一些一般性的建議。

入門

既然本教程的目標(biāo)是優(yōu)化且安全的使用 GCD 調(diào)用來自不同線程的代碼,那么你將從一個近乎完成的叫做?GooglyPuff?的項目入手。

GooglyPuff 是一個沒有優(yōu)化,線程不安全的應(yīng)用,它使用 Core Image 的人臉檢測 API 來覆蓋一對曲棍球眼睛到被檢測到的人臉上。對于基本的圖像,可以從相機膠卷選擇,或用預(yù)設(shè)好的URL從互聯(lián)網(wǎng)下載。

點擊此處下載項目

完成項目下載之后,將其解壓到某個方便的目錄,再用 Xcode 打開它并編譯運行。這個應(yīng)用看起來如下圖所示:

注意當(dāng)你選擇?Le Internet?選項下載圖片時,一個?UIAlertView?過早地彈出。你將在本系列教程地第二部分修復(fù)這個問題。

這個項目中有四個有趣的類:

  • PhotoCollectionViewController:它是應(yīng)用開始的第一個視圖控制器。它用縮略圖展示所有選定的照片。
  • PhotoDetailViewController:它執(zhí)行添加曲棍球眼睛到圖像上的邏輯,并用一個 UIScrollView 來顯示結(jié)果圖片。
  • Photo:這是一個類簇,它根據(jù)一個?NSURL?的實例或一個?ALAsset?的實例來實例化照片。這個類提供一個圖像、縮略圖以及從 URL 下載的狀態(tài)。
  • PhotoManager:它管理所有?Photo?的實例.

用 dispatch_async 處理后臺任務(wù)

回到應(yīng)用并從你的相機膠卷添加一些照片或使用?Le Internet?選項下載一些。

注意在按下?PhotoCollectionViewController?中的一個?UICollectionViewCell?到生成一個新的?PhotoDetailViewController?之間花了多久時間;你會注意到一個明顯的滯后,特別是在比較慢的設(shè)備上查看很大的圖。

在重載?UIViewController 的 viewDidLoad?時容易加入太多雜亂的工作(too much clutter),這通常會引起視圖控制器出現(xiàn)前更長的等待。如果可能,最好是卸下一些工作放到后臺,如果它們不是絕對必須要運行在加載時間里。

這聽起來像是?dispatch_async?能做的事情!

打開?PhotoDetailViewController?并用下面的實現(xiàn)替換?viewDidLoad?:

- (void)viewDidLoad { [super viewDidLoad];NSAssert(_image, @"Image not set; required to use view controller");self.photoImageView.image = _image;//Resize if neccessary to ensure it's not pixelatedif (_image.size.height <= self.photoImageView.bounds.size.height &&_image.size.width <= self.photoImageView.bounds.size.width) {[self.photoImageView setContentMode:UIViewContentModeCenter];}dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{ // 1UIImage *overlayImage = [self faceOverlayImageFromImage:_image];dispatch_async(dispatch_get_main_queue(), ^{ // 2[self fadeInNewImage:overlayImage]; // 3});}); }

下面來說明上面的新代碼所做的事:

  • 你首先將工作從主線程移到全局線程。因為這是一個?dispatch_async()?,Block 會被異步地提交,意味著調(diào)用線程地執(zhí)行將會繼續(xù)。這就使得?viewDidLoad?更早地在主線程完成,讓加載過程感覺起來更加快速。同時,一個人臉檢測過程會啟動并將在稍后完成。
  • 在這里,人臉檢測過程完成,并生成了一個新的圖像。既然你要使用此新圖像更新你的?UIImageView?,那么你就添加一個新的 Block 到主線程。記住——你必須總是在主線程訪問 UIKit 的類。
  • 最后,你用?fadeInNewImage:?更新 UI ,它執(zhí)行一個淡入過程切換到新的曲棍球眼睛圖像。
  • 編譯并運行你的應(yīng)用;選擇一個圖像然后你會注意到視圖控制器加載明顯變快,曲棍球眼睛稍微在之后就加上了。這給應(yīng)用帶來了不錯的效果,和之前的顯示差別巨大。

    進一步,如果你試著加載一個超大的圖像,應(yīng)用不會在加載視圖控制器上“掛住”,這就使得應(yīng)用具有很好伸縮性。

    正如之前提到的,?dispatch_async?添加一個 Block 到隊列就立即返回了。任務(wù)會在之后由 GCD 決定執(zhí)行。當(dāng)你需要在后臺執(zhí)行一個基于網(wǎng)絡(luò)或 CPU 緊張的任務(wù)時就使用?dispatch_async?,這樣就不會阻塞當(dāng)前線程。

    下面是一個關(guān)于在?dispatch_async?上如何以及何時使用不同的隊列類型的快速指導(dǎo):

    • 自定義串行隊列:當(dāng)你想串行執(zhí)行后臺任務(wù)并追蹤它時就是一個好選擇。這消除了資源爭用,因為你知道一次只有一個任務(wù)在執(zhí)行。注意若你需要來自某個方法的數(shù)據(jù),你必須內(nèi)聯(lián)另一個 Block 來找回它或考慮使用?dispatch_sync。
    • 主隊列(串行):這是在一個并發(fā)隊列上完成任務(wù)后更新 UI 的共同選擇。要這樣做,你將在一個 Block 內(nèi)部編寫另一個 Block 。以及,如果你在主隊列調(diào)用?dispatch_async?到主隊列,你能確保這個新任務(wù)將在當(dāng)前方法完成后的某個時間執(zhí)行。
    • 并發(fā)隊列:這是在后臺執(zhí)行非 UI 工作的共同選擇。

    使用 dispatch_after 延后工作

    稍微考慮一下應(yīng)用的 UX 。是否用戶第一次打開應(yīng)用時會困惑于不知道做什么?你是這樣嗎? :]

    如果用戶的?PhotoManager?里還沒有任何照片,那么顯示一個提示會是個好主意!然而,你同樣要考慮用戶的眼睛會如何在主屏幕上瀏覽:如果你太快的顯示一個提示,他們的眼睛還徘徊在視圖的其它部分上,他們很可能會錯過它。

    顯示提示之前延遲一秒鐘就足夠捕捉到用戶的注意,他們此時已經(jīng)第一次看過了應(yīng)用。

    添加如下代碼到到 PhotoCollectionViewController.m 中 showOrHideNavPrompt 的廢止實現(xiàn)里:

    - (void)showOrHideNavPrompt {NSUInteger count = [[PhotoManager sharedManager] photos].count;double delayInSeconds = 1.0;dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, (int64_t)(delayInSeconds * NSEC_PER_SEC)); // 1 dispatch_after(popTime, dispatch_get_main_queue(), ^(void){ // 2 if (!count) {[self.navigationItem setPrompt:@"Add photos with faces to Googlyify them!"];} else {[self.navigationItem setPrompt:nil];}}); }

    showOrHideNavPrompt 在 viewDidLoad 中執(zhí)行,以及 UICollectionView 被重新加載的任何時候。按照注釋數(shù)字順序看看:

  • 你聲明了一個變量指定要延遲的時長。
  • 然后等待?delayInSeconds?給定的時長,再異步地添加一個 Block 到主線程。
  • 編譯并運行應(yīng)用。應(yīng)該有一個輕微地延遲,這有助于抓住用戶的注意力并展示所要做的事情。

    dispatch_after?工作起來就像一個延遲版的?dispatch_async?。你依然不能控制實際的執(zhí)行時間,且一旦?dispatch_after?返回也就不能再取消它。

    不知道何時適合使用?dispatch_after??

    • 自定義串行隊列:在一個自定義串行隊列上使用?dispatch_after?要小心。你最好堅持使用主隊列。
    • 主隊列(串行):是使用?dispatch_after?的好選擇;Xcode 提供了一個不錯的自動完成模版。
    • 并發(fā)隊列:在并發(fā)隊列上使用?dispatch_after?也要小心;你會這樣做就比較罕見。還是在主隊列做這些操作吧。

    讓你的單例線程安全

    單例,不論喜歡還是討厭,它們在 iOS 上的流行情況就像網(wǎng)上的貓。 :]

    一個常見的擔(dān)憂是它們常常不是線程安全的。這個擔(dān)憂十分合理,基于它們的用途:單例常常被多個控制器同時訪問。

    單例的線程擔(dān)憂范圍從初始化開始,到信息的讀和寫。PhotoManager?類被實現(xiàn)為單例——它在目前的狀態(tài)下就會被這些問題所困擾。要看看事情如何很快地失去控制,你將在單例實例上創(chuàng)建一個控制好的競態(tài)條件。

    導(dǎo)航到?PhotoManager.m?并找到?sharedManager?;它看起來如下:

    + (instancetype)sharedManager {static PhotoManager *sharedPhotoManager = nil;if (!sharedPhotoManager) {sharedPhotoManager = [[PhotoManager alloc] init];sharedPhotoManager->_photosArray = [NSMutableArray array];}return sharedPhotoManager; }

    當(dāng)前狀態(tài)下,代碼相當(dāng)簡單;你創(chuàng)建了一個單例并初始化一個叫做?photosArray?的?NSMutableArray?屬性。

    然而,if?條件分支不是線程安全的;如果你多次調(diào)用這個方法,有一個可能性是在某個線程(就叫它線程A)上進入?if語句塊并可能在?sharedPhotoManager?被分配內(nèi)存前發(fā)生一個上下文切換。然后另一個線程(線程B)可能進入?if?,分配單例實例的內(nèi)存,然后退出。

    當(dāng)系統(tǒng)上下文切換回線程A,你會分配另外一個單例實例的內(nèi)存,然后退出。在那個時間點,你有了兩個單例的實例——很明顯這不是你想要的(譯者注:這還能叫單例嗎?)!

    要強制這個(競態(tài))條件發(fā)生,替換?PhotoManager.m?中的?sharedManager?為下面的實現(xiàn):

    + (instancetype)sharedManager {static PhotoManager *sharedPhotoManager = nil;if (!sharedPhotoManager) {[NSThread sleepForTimeInterval:2];sharedPhotoManager = [[PhotoManager alloc] init];NSLog(@"Singleton has memory address at: %@", sharedPhotoManager);[NSThread sleepForTimeInterval:2];sharedPhotoManager->_photosArray = [NSMutableArray array];}return sharedPhotoManager; }

    上面的代碼中你用?NSThread 的 sleepForTimeInterval:?類方法來強制發(fā)生一個上下文切換。

    打開?AppDelegate.m?并添加如下代碼到?application:didFinishLaunchingWithOptions:?的最開始處:

    dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{[PhotoManager sharedManager]; });dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{[PhotoManager sharedManager]; });

    這里創(chuàng)建了多個異步并發(fā)調(diào)用來實例化單例,然后引發(fā)上面描述的競態(tài)條件。

    編譯并運行項目;查看控制臺輸出,你會看到多個單例被實例化,如下所示:

    注意到這里有好幾行顯示著不同地址的單例實例。這明顯違背了單例的目的,對吧?:]

    這個輸出向你展示了臨界區(qū)被執(zhí)行多次,而它只應(yīng)該執(zhí)行一次。現(xiàn)在,固然是你自己強制這樣的狀況發(fā)生,但你可以想像一下這個狀況會怎樣在無意間發(fā)生。

    注意:基于其它你無法控制的系統(tǒng)事件,NSLog 的數(shù)量有時會顯示多個。線程問題極其難以調(diào)試,因為它們往往難以重現(xiàn)。

    要糾正這個狀況,實例化代碼應(yīng)該只執(zhí)行一次,并阻塞其它實例在?if?條件的臨界區(qū)運行。這剛好就是?dispatch_once?能做的事。

    在單例初始化方法中用?dispatch_once?取代?if?條件判斷,如下所示:

    + (instancetype)sharedManager {static PhotoManager *sharedPhotoManager = nil;static dispatch_once_t onceToken;dispatch_once(&onceToken, ^{[NSThread sleepForTimeInterval:2];sharedPhotoManager = [[PhotoManager alloc] init];NSLog(@"Singleton has memory address at: %@", sharedPhotoManager);[NSThread sleepForTimeInterval:2];sharedPhotoManager->_photosArray = [NSMutableArray array];});return sharedPhotoManager; }

    編譯并運行你的應(yīng)用;查看控制臺輸出,你會看到有且僅有一個單例的實例——這就是你對單例的期望!:]

    現(xiàn)在你已經(jīng)明白了防止競態(tài)條件的重要性,從?AppDelegate.m?中移除?dispatch_async?語句,并用下面的實現(xiàn)替換?PhotoManager?單例的初始化:

    + (instancetype)sharedManager {static PhotoManager *sharedPhotoManager = nil;static dispatch_once_t onceToken;dispatch_once(&onceToken, ^{sharedPhotoManager = [[PhotoManager alloc] init];sharedPhotoManager->_photosArray = [NSMutableArray array];});return sharedPhotoManager; }

    dispatch_once()?以線程安全的方式執(zhí)行且僅執(zhí)行其代碼塊一次。試圖訪問臨界區(qū)(即傳遞給?dispatch_once?的代碼)的不同的線程會在臨界區(qū)已有一個線程的情況下被阻塞,直到臨界區(qū)完成為止。

    需要記住的是,這只是讓訪問共享實例線程安全。它絕對沒有讓類本身線程安全。類中可能還有其它競態(tài)條件,例如任何操縱內(nèi)部數(shù)據(jù)的情況。這些需要用其它方式來保證線程安全,例如同步訪問數(shù)據(jù),你將在下面幾個小節(jié)看到。

    處理讀者與寫者問題

    線程安全實例不是處理單例時的唯一問題。如果單例屬性表示一個可變對象,那么你就需要考慮是否那個對象自身線程安全。

    如果問題中的這個對象是一個 Foundation 容器類,那么答案是——“很可能不安全”!Apple 維護一個有用且有些心寒的列表,眾多的 Foundation 類都不是線程安全的。?NSMutableArray,已用于你的單例,正在那個列表里休息。

    雖然許多線程可以同時讀取?NSMutableArray?的一個實例而不會產(chǎn)生問題,但當(dāng)一個線程正在讀取時讓另外一個線程修改數(shù)組就是不安全的。你的單例在目前的狀況下不能預(yù)防這種情況的發(fā)生。

    要分析這個問題,看看?PhotoManager.m?中的?addPhoto:,轉(zhuǎn)載如下:

    - (void)addPhoto:(Photo *)photo {if (photo) {[_photosArray addObject:photo];dispatch_async(dispatch_get_main_queue(), ^{[self postContentAddedNotification];});} }

    這是一個寫方法,它修改一個私有可變數(shù)組對象。

    現(xiàn)在看看?photos?,轉(zhuǎn)載如下:

    - (NSArray *)photos {return [NSArray arrayWithArray:_photosArray]; }

    這是所謂的讀方法,它讀取可變數(shù)組。它為調(diào)用者生成一個不可變的拷貝,防止調(diào)用者不當(dāng)?shù)馗淖償?shù)組,但這不能提供任何保護來對抗當(dāng)一個線程調(diào)用讀方法?photos?的同時另一個線程調(diào)用寫方法?addPhoto:?。

    這就是軟件開發(fā)中經(jīng)典的讀者寫者問題。GCD 通過用?dispatch barriers?創(chuàng)建一個讀者寫者鎖?提供了一個優(yōu)雅的解決方案。

    Dispatch barriers 是一組函數(shù),在并發(fā)隊列上工作時扮演一個串行式的瓶頸。使用 GCD 的障礙(barrier)API 確保提交的 Block 在那個特定時間上是指定隊列上唯一被執(zhí)行的條目。這就意味著所有的先于調(diào)度障礙提交到隊列的條目必能在這個 Block 執(zhí)行前完成。

    當(dāng)這個 Block 的時機到達(dá),調(diào)度障礙執(zhí)行這個 Block 并確保在那個時間里隊列不會執(zhí)行任何其它 Block 。一旦完成,隊列就返回到它默認(rèn)的實現(xiàn)狀態(tài)。 GCD 提供了同步和異步兩種障礙函數(shù)。

    下圖顯示了障礙函數(shù)對多個異步隊列的影響:

    注意到正常部分的操作就如同一個正常的并發(fā)隊列。但當(dāng)障礙執(zhí)行時,它本質(zhì)上就如同一個串行隊列。也就是,障礙是唯一在執(zhí)行的事物。在障礙完成后,隊列回到一個正常并發(fā)隊列的樣子。

    下面是你何時會——和不會——使用障礙函數(shù)的情況:

    • 自定義串行隊列:一個很壞的選擇;障礙不會有任何幫助,因為不管怎樣,一個串行隊列一次都只執(zhí)行一個操作。
    • 全局并發(fā)隊列:要小心;這可能不是最好的主意,因為其它系統(tǒng)可能在使用隊列而且你不能壟斷它們只為你自己的目的。
    • 自定義并發(fā)隊列:這對于原子或臨界區(qū)代碼來說是極佳的選擇。任何你在設(shè)置或?qū)嵗男枰€程安全的事物都是使用障礙的最佳候選。

    由于上面唯一像樣的選擇是自定義并發(fā)隊列,你將創(chuàng)建一個你自己的隊列去處理你的障礙函數(shù)并分開讀和寫函數(shù)。且這個并發(fā)隊列將允許多個多操作同時進行。

    打開?PhotoManager.m,添加如下私有屬性到類擴展中:

    @interface PhotoManager () @property (nonatomic,strong,readonly) NSMutableArray *photosArray; @property (nonatomic, strong) dispatch_queue_t concurrentPhotoQueue; ///< Add this @end

    找到?addPhoto:?并用下面的實現(xiàn)替換它:

    - (void)addPhoto:(Photo *)photo {if (photo) { // 1dispatch_barrier_async(self.concurrentPhotoQueue, ^{ // 2 [_photosArray addObject:photo]; // 3dispatch_async(dispatch_get_main_queue(), ^{ // 4[self postContentAddedNotification]; });});} }

    你新寫的函數(shù)是這樣工作的:

  • 在執(zhí)行下面所有的工作前檢查是否有合法的相片。
  • 添加寫操作到你的自定義隊列。當(dāng)臨界區(qū)在稍后執(zhí)行時,這將是你隊列中唯一執(zhí)行的條目。
  • 這是添加對象到數(shù)組的實際代碼。由于它是一個障礙 Block ,這個 Block 永遠(yuǎn)不會同時和其它 Block 一起在 concurrentPhotoQueue 中執(zhí)行。
  • 最后你發(fā)送一個通知說明完成了添加圖片。這個通知將在主線程被發(fā)送因為它將會做一些 UI 工作,所以在此為了通知,你異步地調(diào)度另一個任務(wù)到主線程。
  • 這就處理了寫操作,但你還需要實現(xiàn)?photos?讀方法并實例化?concurrentPhotoQueue?。

    在寫者打擾的情況下,要確保線程安全,你需要在?concurrentPhotoQueue?隊列上執(zhí)行讀操作。既然你需要從函數(shù)返回,你就不能異步調(diào)度到隊列,因為那樣在讀者函數(shù)返回之前不一定運行。

    在這種情況下,dispatch_sync?就是一個絕好的候選。

    dispatch_sync()?同步地提交工作并在返回前等待它完成。使用?dispatch_sync?跟蹤你的調(diào)度障礙工作,或者當(dāng)你需要等待操作完成后才能使用 Block 處理過的數(shù)據(jù)。如果你使用第二種情況做事,你將不時看到一個?__block?變量寫在?dispatch_sync?范圍之外,以便返回時在?dispatch_sync?使用處理過的對象。

    但你需要很小心。想像如果你調(diào)用?dispatch_sync?并放在你已運行著的當(dāng)前隊列。這會導(dǎo)致死鎖,因為調(diào)用會一直等待直到 Block 完成,但 Block 不能完成(它甚至不會開始!),直到當(dāng)前已經(jīng)存在的任務(wù)完成,而當(dāng)前任務(wù)無法完成!這將迫使你自覺于你正從哪個隊列調(diào)用——以及你正在傳遞進入哪個隊列。

    下面是一個快速總覽,關(guān)于在何時以及何處使用?dispatch_sync?:

    • 自定義串行隊列:在這個狀況下要非常小心!如果你正運行在一個隊列并調(diào)用?dispatch_sync?放在同一個隊列,那你就百分百地創(chuàng)建了一個死鎖。
    • 主隊列(串行):同上面的理由一樣,必須非常小心!這個狀況同樣有潛在的導(dǎo)致死鎖的情況。
    • 并發(fā)隊列:這才是做同步工作的好選擇,不論是通過調(diào)度障礙,或者需要等待一個任務(wù)完成才能執(zhí)行進一步處理的情況。

    繼續(xù)在?PhotoManager.m?上工作,用下面的實現(xiàn)替換?photos?:

    - (NSArray *)photos {__block NSArray *array; // 1dispatch_sync(self.concurrentPhotoQueue, ^{ // 2array = [NSArray arrayWithArray:_photosArray]; // 3});return array; }

    這就是你的讀函數(shù)。按順序看看編過號的注釋,有這些:

  • __block?關(guān)鍵字允許對象在 Block 內(nèi)可變。沒有它,array?在 Block 內(nèi)部就只是只讀的,你的代碼甚至不能通過編譯。
  • 在?concurrentPhotoQueue?上同步調(diào)度來執(zhí)行讀操作。
  • 將相片數(shù)組存儲在?array?內(nèi)并返回它。
  • 最后,你需要實例化你的?concurrentPhotoQueue?屬性。修改?sharedManager?以便像下面這樣初始化隊列:

    + (instancetype)sharedManager {static PhotoManager *sharedPhotoManager = nil;static dispatch_once_t onceToken;dispatch_once(&onceToken, ^{sharedPhotoManager = [[PhotoManager alloc] init];sharedPhotoManager->_photosArray = [NSMutableArray array];// ADD THIS:sharedPhotoManager->_concurrentPhotoQueue = dispatch_queue_create("com.selander.GooglyPuff.photoQueue",DISPATCH_QUEUE_CONCURRENT); });return sharedPhotoManager; }

    這里使用?dispatch_queue_create?初始化?concurrentPhotoQueue?為一個并發(fā)隊列。第一個參數(shù)是反向DNS樣式命名慣例;確保它是描述性的,將有助于調(diào)試。第二個參數(shù)指定你的隊列是串行還是并發(fā)。

    注意:當(dāng)你在網(wǎng)上搜索例子時,你會經(jīng)常看人們傳遞?0?或者?NULL?給?dispatch_queue_create?的第二個參數(shù)。這是一個創(chuàng)建串行隊列的過時方式;明確你的參數(shù)總是更好。

    恭喜——你的?PhotoManager?單例現(xiàn)在是線程安全的了。不論你在何處或怎樣讀或?qū)懩愕恼掌?#xff0c;你都有這樣的自信,即它將以安全的方式完成,不會出現(xiàn)任何驚嚇。

    A Visual Review of Queueing 隊列的虛擬回顧

    依然沒有 100% 地掌握 GCD 的要領(lǐng)?確保你可以使用 GCD 函數(shù)輕松地創(chuàng)建簡單的例子,使用斷點和?NSLog?語句保證自己明白當(dāng)下發(fā)生的情況。

    我在下面提供了兩個 GIF動畫來幫助你鞏固對?dispatch_async?和?dispatch_sync?的理解。包含在每個 GIF 中的代碼可以提供視覺輔助;仔細(xì)注意 GIF 左邊顯示代碼斷點的每一步,以及右邊相關(guān)隊列的狀態(tài)。

    dispatch_sync 回顧

    - (void)viewDidLoad {[super viewDidLoad];dispatch_sync(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{NSLog(@"First Log");});NSLog(@"Second Log"); }

    下面是圖中幾個步驟的說明:

  • 主隊列一路按順序執(zhí)行任務(wù)——接著是一個實例化?UIViewController?的任務(wù),其中包含了?viewDidLoad?。
  • viewDidLoad?在主線程執(zhí)行。
  • 主線程目前在?viewDidLoad?內(nèi),正要到達(dá)?dispatch_sync?。
  • dispatch_sync?Block 被添加到一個全局隊列中,將在稍后執(zhí)行。進程將在主線程掛起直到該 Block 完成。同時,全局隊列并發(fā)處理任務(wù);要記得 Block 在全局隊列中將按照 FIFO 順序出列,但可以并發(fā)執(zhí)行。
  • 全局隊列處理?dispatch_sync?Block 加入之前已經(jīng)出現(xiàn)在隊列中的任務(wù)。
  • 終于,輪到?dispatch_sync?Block 。
  • 這個 Block 完成,因此主線程上的任務(wù)可以恢復(fù)。
  • viewDidLoad?方法完成,主隊列繼續(xù)處理其他任務(wù)。
  • dispatch_sync?添加任務(wù)到一個隊列并等待直到任務(wù)完成。dispatch_async?做類似的事情,但不同之處是它不會等待任務(wù)的完成,而是立即繼續(xù)“調(diào)用線程”的其它任務(wù)。

    dispatch_async 回顧

    - (void)viewDidLoad {[super viewDidLoad];dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0), ^{NSLog(@"First Log");});NSLog(@"Second Log"); }

  • 主隊列一路按順序執(zhí)行任務(wù)——接著是一個實例化?UIViewController?的任務(wù),其中包含了?viewDidLoad?。
  • viewDidLoad?在主線程執(zhí)行。
  • 主線程目前在?viewDidLoad?內(nèi),正要到達(dá)?dispatch_async?。
  • dispatch_async?Block 被添加到一個全局隊列中,將在稍后執(zhí)行。
  • viewDidLoad?在添加?dispatch_async?到全局隊列后繼續(xù)進行,主線程把注意力轉(zhuǎn)向剩下的任務(wù)。同時,全局隊列并發(fā)地處理它未完成地任務(wù)。記住 Block 在全局隊列中將按照 FIFO 順序出列,但可以并發(fā)執(zhí)行。
  • 添加到?dispatch_async?的代碼塊開始執(zhí)行。
  • dispatch_async?Block 完成,兩個?NSLog?語句將它們的輸出放在控制臺上。
  • 在這個特定的實例中,第二個?NSLog?語句執(zhí)行,跟著是第一個?NSLog?語句。并不總是這樣——著取決于給定時刻硬件正在做的事情,而且你無法控制或知曉哪個語句會先執(zhí)行。“第一個”?NSLog?在某些調(diào)用情況下會第一個執(zhí)行。

    下一步怎么走?

    在本教程中,你學(xué)習(xí)了如何讓你的代碼線程安全,以及在執(zhí)行 CPU 密集型任務(wù)時如何保持主線程的響應(yīng)性。

    你可以下載?GooglyPuff 項目,它包含了目前所有本教程中編寫的實現(xiàn)。在本教程的第二部分,你將繼續(xù)改進這個項目。

    如果你計劃優(yōu)化你自己的應(yīng)用,那你應(yīng)該用?Instruments?中的?Time Profile?模版分析你的工作。對這個工具的使用超出了本教程的范圍,你可以看看?如何使用Instruments?來得到一個很好的概述。

    同時請確保在真實設(shè)備上分析,而在模擬器上測試會對程序速度產(chǎn)生非常不準(zhǔn)確的印象。

    在教程的下一部分,你將更加深入到 GCD 的 API 中,做一些更 Cool 的東西。

    如果你有任何問題或評論,可自由地加入下方的討論!

    譯者注:歡迎轉(zhuǎn)載,但請一定注明出處!?https://github.com/nixzhu/dev-blog

    歡迎轉(zhuǎn)發(fā)此條微博?http://weibo.com/2076580237/B0tjrEQr9?以分享給更多人!

    如果你認(rèn)為這篇翻譯不錯,也有閑錢,那你可以用支付寶隨便捐助一點,以慰勞譯者的辛苦:

    總結(jié)

    以上是生活随笔為你收集整理的GCD 深入理解:第一部分的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

    无码av最新清无码专区吞精 | 国产成人av免费观看 | 激情亚洲一区国产精品 | 丰满少妇人妻久久久久久 | 中文毛片无遮挡高清免费 | 国产无av码在线观看 | 久久人妻内射无码一区三区 | 黑人巨大精品欧美黑寡妇 | 日韩精品无码一本二本三本色 | 久久伊人色av天堂九九小黄鸭 | 国産精品久久久久久久 | 久久亚洲国产成人精品性色 | 久久人人爽人人爽人人片ⅴ | 精品厕所偷拍各类美女tp嘘嘘 | 中文字幕中文有码在线 | 久久久成人毛片无码 | 青青草原综合久久大伊人精品 | 久青草影院在线观看国产 | 亚洲国产精品久久久久久 | 午夜成人1000部免费视频 | 久久久中文字幕日本无吗 | 成熟人妻av无码专区 | 99久久婷婷国产综合精品青草免费 | 无码国产乱人伦偷精品视频 | 老司机亚洲精品影院无码 | 精品久久8x国产免费观看 | 国产精品自产拍在线观看 | 亚洲の无码国产の无码影院 | 97色伦图片97综合影院 | 国产人妻精品一区二区三区不卡 | 性开放的女人aaa片 | 久久久国产精品无码免费专区 | 国产午夜精品一区二区三区嫩草 | 老太婆性杂交欧美肥老太 | 午夜无码区在线观看 | 久久五月精品中文字幕 | 国产内射老熟女aaaa | 欧美日本精品一区二区三区 | 野外少妇愉情中文字幕 | 中国女人内谢69xxxx | 国产偷抇久久精品a片69 | 国精产品一区二区三区 | www成人国产高清内射 | 亚洲一区二区三区四区 | 欧美日韩人成综合在线播放 | 成人精品视频一区二区三区尤物 | 国精品人妻无码一区二区三区蜜柚 | 亚洲色在线无码国产精品不卡 | 亚洲男人av天堂午夜在 | 少妇被粗大的猛进出69影院 | 欧美性色19p | 精品亚洲韩国一区二区三区 | 狠狠色色综合网站 | а√天堂www在线天堂小说 | 国产av无码专区亚洲awww | 永久免费精品精品永久-夜色 | 国产高清不卡无码视频 | 欧美日韩综合一区二区三区 | 丁香花在线影院观看在线播放 | 欧美日韩久久久精品a片 | 特黄特色大片免费播放器图片 | 久久久精品人妻久久影视 | 3d动漫精品啪啪一区二区中 | а√天堂www在线天堂小说 | 久久久中文字幕日本无吗 | 亚洲国产精品久久久久久 | 18精品久久久无码午夜福利 | 国产熟妇高潮叫床视频播放 | 一二三四社区在线中文视频 | 搡女人真爽免费视频大全 | 欧美日韩在线亚洲综合国产人 | 无码av中文字幕免费放 | www一区二区www免费 | 欧美人与牲动交xxxx | 国产一区二区三区四区五区加勒比 | 国产精品福利视频导航 | 久久久久久久久888 | 性欧美大战久久久久久久 | 色窝窝无码一区二区三区色欲 | 成人免费视频视频在线观看 免费 | 亚洲一区二区三区香蕉 | 欧美阿v高清资源不卡在线播放 | 又大又硬又爽免费视频 | 国内精品人妻无码久久久影院 | 久久久久亚洲精品中文字幕 | 国产精品-区区久久久狼 | 亚无码乱人伦一区二区 | 丰满少妇高潮惨叫视频 | 性色欲网站人妻丰满中文久久不卡 | 成人无码精品1区2区3区免费看 | 国产情侣作爱视频免费观看 | 欧美三级a做爰在线观看 | 粉嫩少妇内射浓精videos | 亚洲成a人一区二区三区 | 暴力强奷在线播放无码 | 亚洲国产精品一区二区第一页 | 欧美老妇交乱视频在线观看 | 国产一区二区三区日韩精品 | 香港三级日本三级妇三级 | 国产两女互慰高潮视频在线观看 | 国产做国产爱免费视频 | 无码人妻少妇伦在线电影 | 四虎永久在线精品免费网址 | 97无码免费人妻超级碰碰夜夜 | 一本久久a久久精品vr综合 | 无码人妻精品一区二区三区下载 | 性啪啪chinese东北女人 | 天天av天天av天天透 | 日韩亚洲欧美中文高清在线 | 国产一区二区三区日韩精品 | 67194成是人免费无码 | 国产精品a成v人在线播放 | 久久99国产综合精品 | 无遮无挡爽爽免费视频 | 亚洲中文字幕乱码av波多ji | 全球成人中文在线 | 国产av无码专区亚洲a∨毛片 | √天堂资源地址中文在线 | 青草青草久热国产精品 | 人妻与老人中文字幕 | 亚洲无人区一区二区三区 | 国产午夜福利100集发布 | 少妇邻居内射在线 | 成人欧美一区二区三区黑人免费 | 色窝窝无码一区二区三区色欲 | 欧美35页视频在线观看 | 亚洲精品无码国产 | 偷窥日本少妇撒尿chinese | 日本一区二区三区免费高清 | 国内综合精品午夜久久资源 | 欧美性猛交xxxx富婆 | 中文字幕日产无线码一区 | 亚洲精品久久久久中文第一幕 | 亚洲狠狠婷婷综合久久 | 18黄暴禁片在线观看 | 国产精品久久久一区二区三区 | 在线天堂新版最新版在线8 | 奇米影视7777久久精品人人爽 | 久久熟妇人妻午夜寂寞影院 | 人人澡人人妻人人爽人人蜜桃 | 天海翼激烈高潮到腰振不止 | 人妻少妇精品无码专区动漫 | 久久精品国产一区二区三区肥胖 | 国产精品久久久一区二区三区 | 少妇无套内谢久久久久 | 婷婷色婷婷开心五月四房播播 | 国产亚洲精品久久久久久大师 | 国产美女精品一区二区三区 | 国产性生交xxxxx无码 | 女人被男人爽到呻吟的视频 | 欧美日韩一区二区免费视频 | 性色av无码免费一区二区三区 | 自拍偷自拍亚洲精品被多人伦好爽 | 成人无码视频免费播放 | 久久熟妇人妻午夜寂寞影院 | 国产av一区二区三区最新精品 | 亚洲日韩一区二区三区 | 永久免费观看国产裸体美女 | 成人精品视频一区二区 | 一本久道久久综合婷婷五月 | 国产成人无码av在线影院 | 久久久久成人精品免费播放动漫 | 国产凸凹视频一区二区 | 国内精品久久毛片一区二区 | 欧美日韩在线亚洲综合国产人 | 精品国产成人一区二区三区 | 欧洲精品码一区二区三区免费看 | 蜜桃av抽搐高潮一区二区 | 午夜无码人妻av大片色欲 | 亚洲一区二区三区偷拍女厕 | 永久黄网站色视频免费直播 | 国产精品视频免费播放 | 麻豆国产丝袜白领秘书在线观看 | 老司机亚洲精品影院 | 夜夜影院未满十八勿进 | 亚洲精品一区二区三区四区五区 | 欧美人与物videos另类 | 无码国内精品人妻少妇 | 亚洲国产欧美日韩精品一区二区三区 | 久久久久久a亚洲欧洲av冫 | 日韩精品乱码av一区二区 | 久久久久av无码免费网 | 少妇性俱乐部纵欲狂欢电影 | 久久综合色之久久综合 | 网友自拍区视频精品 | 久久成人a毛片免费观看网站 | 理论片87福利理论电影 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国内丰满熟女出轨videos | 国产无遮挡又黄又爽又色 | 97夜夜澡人人双人人人喊 | 成人无码精品1区2区3区免费看 | 亚洲精品国产a久久久久久 | 中文字幕av无码一区二区三区电影 | 丁香花在线影院观看在线播放 | 国产无av码在线观看 | 国产综合久久久久鬼色 | 亚洲色欲色欲欲www在线 | 午夜无码人妻av大片色欲 | 中文字幕日韩精品一区二区三区 | 澳门永久av免费网站 | 精品aⅴ一区二区三区 | 亚洲色大成网站www | 久精品国产欧美亚洲色aⅴ大片 | 日韩av无码中文无码电影 | 国产人妻久久精品二区三区老狼 | 国产激情无码一区二区 | 曰本女人与公拘交酡免费视频 | 国产人妻大战黑人第1集 | 亚洲一区二区三区在线观看网站 | 无遮无挡爽爽免费视频 | 国产精品毛片一区二区 | 国产精品怡红院永久免费 | 国产成人无码区免费内射一片色欲 | 婷婷色婷婷开心五月四房播播 | 久久久久久久久蜜桃 | 动漫av一区二区在线观看 | 亚洲综合无码一区二区三区 | 免费无码午夜福利片69 | 国产亚洲精品久久久久久 | 亚洲中文字幕在线无码一区二区 | 伊在人天堂亚洲香蕉精品区 | 日日干夜夜干 | 久久亚洲中文字幕精品一区 | 欧美精品一区二区精品久久 | 欧美日韩亚洲国产精品 | 久久国语露脸国产精品电影 | 乱码午夜-极国产极内射 | 亚洲色大成网站www | 全球成人中文在线 | 西西人体www44rt大胆高清 | 激情内射亚州一区二区三区爱妻 | 亚洲精品午夜国产va久久成人 | 国产偷自视频区视频 | 少妇无套内谢久久久久 | 激情内射日本一区二区三区 | 曰韩少妇内射免费播放 | 久久午夜无码鲁丝片 | 亚洲国产精品久久久久久 | 成人影院yy111111在线观看 | 欧美三级不卡在线观看 | 丰满岳乱妇在线观看中字无码 | 在线 国产 欧美 亚洲 天堂 | 精品人妻中文字幕有码在线 | 日韩欧美中文字幕公布 | 综合网日日天干夜夜久久 | 免费网站看v片在线18禁无码 | 美女毛片一区二区三区四区 | 亚洲日韩精品欧美一区二区 | 一本色道久久综合狠狠躁 | 成人无码精品1区2区3区免费看 | 未满小14洗澡无码视频网站 | 妺妺窝人体色www婷婷 | 亚洲一区二区三区香蕉 | 荫蒂被男人添的好舒服爽免费视频 | 永久免费观看美女裸体的网站 | 精品国精品国产自在久国产87 | 欧美猛少妇色xxxxx | 国产精品久久精品三级 | 性开放的女人aaa片 | 国产精品二区一区二区aⅴ污介绍 | 国产特级毛片aaaaaa高潮流水 | 少妇高潮一区二区三区99 | 天堂а√在线地址中文在线 | 日韩精品无码免费一区二区三区 | 偷窥日本少妇撒尿chinese | 正在播放东北夫妻内射 | 正在播放东北夫妻内射 | 兔费看少妇性l交大片免费 | www一区二区www免费 | 人人妻人人澡人人爽欧美一区九九 | 欧美xxxx黑人又粗又长 | 清纯唯美经典一区二区 | 日本乱人伦片中文三区 | 亚洲欧美精品aaaaaa片 | 天堂а√在线中文在线 | 亚洲 a v无 码免 费 成 人 a v | 日本熟妇浓毛 | 欧美三级a做爰在线观看 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 九九热爱视频精品 | 久久亚洲精品中文字幕无男同 | 亚洲精品美女久久久久久久 | 国产精品18久久久久久麻辣 | 欧美丰满熟妇xxxx性ppx人交 | 高潮毛片无遮挡高清免费视频 | 亚洲а∨天堂久久精品2021 | 97色伦图片97综合影院 | 97久久超碰中文字幕 | 精品国产aⅴ无码一区二区 | 日日天干夜夜狠狠爱 | 久久精品中文字幕一区 | 精品人妻中文字幕有码在线 | 高中生自慰www网站 | 日日鲁鲁鲁夜夜爽爽狠狠 | 未满成年国产在线观看 | 久久精品国产大片免费观看 | 国产精品久久久久7777 | 一本色道婷婷久久欧美 | 伊人久久大香线蕉av一区二区 | 色欲av亚洲一区无码少妇 | 两性色午夜免费视频 | 成人免费视频视频在线观看 免费 | 欧美丰满熟妇xxxx | 日本一区二区三区免费高清 | 日韩av无码一区二区三区 | 国产精品久久久久影院嫩草 | 欧美亚洲国产一区二区三区 | 日日橹狠狠爱欧美视频 | 国产免费久久久久久无码 | 国产无套粉嫩白浆在线 | 少妇性荡欲午夜性开放视频剧场 | 高清不卡一区二区三区 | 蜜桃无码一区二区三区 | 中文字幕无码热在线视频 | 久久伊人色av天堂九九小黄鸭 | 亚洲国产精品毛片av不卡在线 | 精品久久久无码中文字幕 | 国语精品一区二区三区 | 亚洲人成网站色7799 | 激情内射日本一区二区三区 | 中文字幕无码视频专区 | 国产又粗又硬又大爽黄老大爷视 | 水蜜桃亚洲一二三四在线 | 国产乱子伦视频在线播放 | 亚洲呦女专区 | 国产乱人偷精品人妻a片 | 久久精品女人天堂av免费观看 | 日日摸天天摸爽爽狠狠97 | 又粗又大又硬毛片免费看 | 无遮挡国产高潮视频免费观看 | 高清国产亚洲精品自在久久 | 日本一本二本三区免费 | 久久久久国色av免费观看性色 | 四十如虎的丰满熟妇啪啪 | 亚洲精品国产精品乱码视色 | 亚洲啪av永久无码精品放毛片 | 久久久久久久女国产乱让韩 | 亚洲狠狠婷婷综合久久 | 亚洲国产精品毛片av不卡在线 | 黑人大群体交免费视频 | 久久国产精品二国产精品 | 国产婷婷色一区二区三区在线 | 俺去俺来也在线www色官网 | 国产人妻人伦精品 | 久久精品中文闷骚内射 | 性生交片免费无码看人 | 国产福利视频一区二区 | 少妇人妻偷人精品无码视频 | 国产欧美熟妇另类久久久 | 丰满少妇熟乱xxxxx视频 | 国产午夜手机精彩视频 | a在线亚洲男人的天堂 | 国产成人无码午夜视频在线观看 | 性色av无码免费一区二区三区 | 成人无码影片精品久久久 | 成人无码精品1区2区3区免费看 | 捆绑白丝粉色jk震动捧喷白浆 | 青春草在线视频免费观看 | 97精品人妻一区二区三区香蕉 | 日日摸天天摸爽爽狠狠97 | 久久午夜夜伦鲁鲁片无码免费 | 美女极度色诱视频国产 | 亚洲日韩av一区二区三区四区 | 97久久国产亚洲精品超碰热 | 夜夜高潮次次欢爽av女 | 香港三级日本三级妇三级 | 亚洲综合无码一区二区三区 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 一二三四社区在线中文视频 | 亚洲理论电影在线观看 | 国产激情精品一区二区三区 | 欧美成人家庭影院 | 老太婆性杂交欧美肥老太 | 婷婷丁香五月天综合东京热 | 国产精品-区区久久久狼 | 欧美国产日韩久久mv | 国产美女极度色诱视频www | 中文字幕无码视频专区 | 亚洲熟妇色xxxxx欧美老妇y | 中文无码伦av中文字幕 | 国产激情无码一区二区app | 特黄特色大片免费播放器图片 | 色综合久久久无码中文字幕 | 人妻插b视频一区二区三区 | 97色伦图片97综合影院 | 中文字幕无码日韩专区 | 精品国产福利一区二区 | 蜜桃臀无码内射一区二区三区 | 亚洲精品国产精品乱码不卡 | 色综合久久88色综合天天 | 国产成人一区二区三区在线观看 | 欧美激情一区二区三区成人 | 波多野结衣高清一区二区三区 | 久久国产精品萌白酱免费 | 自拍偷自拍亚洲精品10p | 一本色道久久综合亚洲精品不卡 | 老太婆性杂交欧美肥老太 | 牲欲强的熟妇农村老妇女视频 | 精品无人区无码乱码毛片国产 | 欧美日韩一区二区免费视频 | 熟妇女人妻丰满少妇中文字幕 | 色五月五月丁香亚洲综合网 | 久久zyz资源站无码中文动漫 | 亚洲国产精品一区二区第一页 | 亚洲国产欧美日韩精品一区二区三区 | 荫蒂被男人添的好舒服爽免费视频 | 久久99国产综合精品 | 国产麻豆精品精东影业av网站 | 国产无套粉嫩白浆在线 | 少妇激情av一区二区 | 理论片87福利理论电影 | 国产成人久久精品流白浆 | 国产成人精品视频ⅴa片软件竹菊 | 无遮无挡爽爽免费视频 | 亚洲精品久久久久中文第一幕 | 日日摸天天摸爽爽狠狠97 | 欧美zoozzooz性欧美 | 日本熟妇乱子伦xxxx | 国产精品久久久久7777 | 国产后入清纯学生妹 | 精品aⅴ一区二区三区 | 99在线 | 亚洲 | 亚洲第一网站男人都懂 | 国产人妻久久精品二区三区老狼 | 久久无码专区国产精品s | 99在线 | 亚洲 | av小次郎收藏 | 无码午夜成人1000部免费视频 | 亚洲一区二区观看播放 | 久久综合九色综合欧美狠狠 | 乱中年女人伦av三区 | 国产美女极度色诱视频www | 精品 日韩 国产 欧美 视频 | 老太婆性杂交欧美肥老太 | 国产麻豆精品一区二区三区v视界 | 高清不卡一区二区三区 | 熟妇人妻无码xxx视频 | 亚洲乱码中文字幕在线 | 亚洲无人区午夜福利码高清完整版 | 久久久久成人片免费观看蜜芽 | 高中生自慰www网站 | 国产激情艳情在线看视频 | 极品嫩模高潮叫床 | 荫蒂被男人添的好舒服爽免费视频 | 久久久久久久女国产乱让韩 | 人妻中文无码久热丝袜 | 夜夜躁日日躁狠狠久久av | 国产人妻精品午夜福利免费 | 性开放的女人aaa片 | 亚洲日韩av一区二区三区四区 | 国产成人一区二区三区在线观看 | 欧美猛少妇色xxxxx | 亚洲va欧美va天堂v国产综合 | 婷婷五月综合缴情在线视频 | 国产婷婷色一区二区三区在线 | 伦伦影院午夜理论片 | 久久成人a毛片免费观看网站 | 人人妻人人澡人人爽欧美一区 | 欧美猛少妇色xxxxx | 在线播放免费人成毛片乱码 | 岛国片人妻三上悠亚 | 玩弄中年熟妇正在播放 | 午夜理论片yy44880影院 | 黄网在线观看免费网站 | 国产精品久久久午夜夜伦鲁鲁 | 久久久成人毛片无码 | 性做久久久久久久免费看 | 99视频精品全部免费免费观看 | 又紧又大又爽精品一区二区 | 98国产精品综合一区二区三区 | 99久久人妻精品免费二区 | 中文字幕av日韩精品一区二区 | 成在人线av无码免费 | 国产黑色丝袜在线播放 | 国产色视频一区二区三区 | 老熟妇乱子伦牲交视频 | 精品国产一区二区三区四区 | 亚洲阿v天堂在线 | 樱花草在线播放免费中文 | 国产成人无码a区在线观看视频app | 帮老师解开蕾丝奶罩吸乳网站 | 国产亚洲精品久久久久久久久动漫 | 欧美成人午夜精品久久久 | 天天摸天天透天天添 | 亚洲一区二区三区国产精华液 | 国产综合色产在线精品 | 亚欧洲精品在线视频免费观看 | 四十如虎的丰满熟妇啪啪 | 欧美精品一区二区精品久久 | 欧美 日韩 人妻 高清 中文 | 国产精品福利视频导航 | 99久久无码一区人妻 | 欧美精品一区二区精品久久 | 国产av无码专区亚洲awww | 精品水蜜桃久久久久久久 | 亚洲综合无码久久精品综合 | 99久久婷婷国产综合精品青草免费 | 日韩精品成人一区二区三区 | 日韩成人一区二区三区在线观看 | 玩弄少妇高潮ⅹxxxyw | 成年美女黄网站色大免费全看 | 内射巨臀欧美在线视频 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 无码吃奶揉捏奶头高潮视频 | 四虎影视成人永久免费观看视频 | 久久久久久av无码免费看大片 | 自拍偷自拍亚洲精品被多人伦好爽 | 亚拍精品一区二区三区探花 | 最近中文2019字幕第二页 | 午夜精品久久久内射近拍高清 | 一个人看的视频www在线 | 樱花草在线播放免费中文 | 亚洲の无码国产の无码影院 | 精品久久久久久人妻无码中文字幕 | 亚洲精品午夜国产va久久成人 | 天堂а√在线中文在线 | 国产凸凹视频一区二区 | 一本大道伊人av久久综合 | 亚洲乱码国产乱码精品精 | 色欲av亚洲一区无码少妇 | 亚洲精品www久久久 | 国产精品人人妻人人爽 | 久久精品女人天堂av免费观看 | 强伦人妻一区二区三区视频18 | 亚洲国产综合无码一区 | 99精品无人区乱码1区2区3区 | 中文字幕av日韩精品一区二区 | 久久综合久久自在自线精品自 | 国产精品资源一区二区 | 国产成人久久精品流白浆 | 国色天香社区在线视频 | 丰满少妇女裸体bbw | 娇妻被黑人粗大高潮白浆 | 乱人伦人妻中文字幕无码 | 男女超爽视频免费播放 | 国精产品一品二品国精品69xx | 黑人玩弄人妻中文在线 | 精品aⅴ一区二区三区 | 国产亚洲欧美日韩亚洲中文色 | 亚洲日韩av片在线观看 | 日产精品99久久久久久 | 亚洲成av人影院在线观看 | 无码人妻av免费一区二区三区 | 国内老熟妇对白xxxxhd | 久久综合狠狠综合久久综合88 | 国产特级毛片aaaaaa高潮流水 | 亚洲欧美色中文字幕在线 | 国产精品毛多多水多 | 欧美大屁股xxxxhd黑色 | 最新版天堂资源中文官网 | 国产亚洲精品久久久久久久久动漫 | 日本一区二区三区免费高清 | 红桃av一区二区三区在线无码av | 欧美黑人性暴力猛交喷水 | 久久综合狠狠综合久久综合88 | 国产人妻精品一区二区三区不卡 | 国産精品久久久久久久 | 欧美肥老太牲交大战 | 亚洲精品欧美二区三区中文字幕 | 日产精品99久久久久久 | 曰本女人与公拘交酡免费视频 | 男女下面进入的视频免费午夜 | 无码人妻精品一区二区三区下载 | 国产真实夫妇视频 | 无码免费一区二区三区 | 中国女人内谢69xxxxxa片 | 精品偷自拍另类在线观看 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 四虎影视成人永久免费观看视频 | 久久国内精品自在自线 | 欧美日韩色另类综合 | 激情国产av做激情国产爱 | 午夜精品一区二区三区在线观看 | 青青青爽视频在线观看 | 亚洲成a人片在线观看无码3d | 人妻无码αv中文字幕久久琪琪布 | 久久久精品国产sm最大网站 | 国产欧美亚洲精品a | 中文无码精品a∨在线观看不卡 | 人人澡人摸人人添 | 日日干夜夜干 | 亚洲精品久久久久avwww潮水 | 欧美成人家庭影院 | 国产精品久久久久久亚洲毛片 | 免费国产成人高清在线观看网站 | 中文字幕无码日韩专区 | 无套内谢的新婚少妇国语播放 | 国产人妻大战黑人第1集 | 欧美zoozzooz性欧美 | 熟女俱乐部五十路六十路av | 国产高清av在线播放 | 草草网站影院白丝内射 | 娇妻被黑人粗大高潮白浆 | 欧美性生交xxxxx久久久 | 熟女俱乐部五十路六十路av | 欧美精品无码一区二区三区 | 久久久av男人的天堂 | 精品无码成人片一区二区98 | а√天堂www在线天堂小说 | 国产亚洲精品久久久久久久久动漫 | 日本一区二区三区免费播放 | 日韩亚洲欧美中文高清在线 | 国产欧美亚洲精品a | 色婷婷久久一区二区三区麻豆 | 久久久精品国产sm最大网站 | 亚洲一区二区观看播放 | 欧美亚洲国产一区二区三区 | 老头边吃奶边弄进去呻吟 | 午夜免费福利小电影 | 亚洲精品一区三区三区在线观看 | 国产av一区二区三区最新精品 | 装睡被陌生人摸出水好爽 | 亚洲精品www久久久 | 日韩av无码一区二区三区不卡 | 精品久久久久久亚洲精品 | 无码国模国产在线观看 | 亚洲一区二区三区国产精华液 | 天天拍夜夜添久久精品 | 国内少妇偷人精品视频免费 | 国产综合色产在线精品 | 久久亚洲国产成人精品性色 | 国产午夜福利100集发布 | 全黄性性激高免费视频 | 精品无码国产一区二区三区av | 无码福利日韩神码福利片 | 成人av无码一区二区三区 | 中文精品无码中文字幕无码专区 | 午夜肉伦伦影院 | 奇米影视888欧美在线观看 | 一本加勒比波多野结衣 | 亚洲欧美精品伊人久久 | 又紧又大又爽精品一区二区 | 99久久99久久免费精品蜜桃 | 中文字幕人妻无码一区二区三区 | 久9re热视频这里只有精品 | 狠狠色噜噜狠狠狠狠7777米奇 | 久久亚洲中文字幕精品一区 | 久久伊人色av天堂九九小黄鸭 | 图片区 小说区 区 亚洲五月 | 国产成人精品久久亚洲高清不卡 | 久久久精品456亚洲影院 | 曰本女人与公拘交酡免费视频 | 国产精品久久久av久久久 | 国产人妻精品一区二区三区 | 国产精品美女久久久久av爽李琼 | 国产在线精品一区二区三区直播 | 亚洲男人av天堂午夜在 | 男人和女人高潮免费网站 | 男人的天堂av网站 | 中国女人内谢69xxxxxa片 | 天天综合网天天综合色 | 亚洲综合另类小说色区 | 无码一区二区三区在线观看 | 亚洲精品久久久久中文第一幕 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 成人欧美一区二区三区黑人 | 人人妻人人澡人人爽欧美一区九九 | 人人妻人人澡人人爽人人精品浪潮 | 国产精品国产自线拍免费软件 | 精品成人av一区二区三区 | 国产无套粉嫩白浆在线 | 又紧又大又爽精品一区二区 | 乱人伦人妻中文字幕无码 | 国产成人一区二区三区在线观看 | 98国产精品综合一区二区三区 | 久久久久se色偷偷亚洲精品av | 性欧美熟妇videofreesex | 强奷人妻日本中文字幕 | 精品厕所偷拍各类美女tp嘘嘘 | 亚洲va欧美va天堂v国产综合 | 纯爱无遮挡h肉动漫在线播放 | 亚洲日本一区二区三区在线 | 日韩精品乱码av一区二区 | 99麻豆久久久国产精品免费 | 无码帝国www无码专区色综合 | 日本精品久久久久中文字幕 | 亚洲欧美综合区丁香五月小说 | 色诱久久久久综合网ywww | 国产肉丝袜在线观看 | 人妻少妇被猛烈进入中文字幕 | 午夜精品久久久内射近拍高清 | 久久久久久av无码免费看大片 | 欧美老人巨大xxxx做受 | 欧美日韩人成综合在线播放 | 成 人 免费观看网站 | 日本va欧美va欧美va精品 | 国产av久久久久精东av | 国产乱子伦视频在线播放 | 99久久婷婷国产综合精品青草免费 | 亚洲欧美日韩成人高清在线一区 | 久久综合久久自在自线精品自 | 一个人看的视频www在线 | 成人片黄网站色大片免费观看 | 51国偷自产一区二区三区 | 国产午夜视频在线观看 | 亚洲成av人综合在线观看 | 人妻互换免费中文字幕 | 少妇久久久久久人妻无码 | 人妻人人添人妻人人爱 | 精品成在人线av无码免费看 | 欧美成人免费全部网站 | 对白脏话肉麻粗话av | 日韩欧美中文字幕在线三区 | 日日橹狠狠爱欧美视频 | 奇米影视888欧美在线观看 | 天天摸天天透天天添 | 欧美激情一区二区三区成人 | 男人扒开女人内裤强吻桶进去 | 国产精品资源一区二区 | 欧美日韩亚洲国产精品 | 亚洲a无码综合a国产av中文 | 亚洲小说春色综合另类 | 亚洲成av人片天堂网无码】 | 国产手机在线αⅴ片无码观看 | 久久人人爽人人人人片 | 亚洲精品鲁一鲁一区二区三区 | 久久成人a毛片免费观看网站 | 国产网红无码精品视频 | 人妻少妇精品无码专区二区 | 精品夜夜澡人妻无码av蜜桃 | 国产精品18久久久久久麻辣 | 无码一区二区三区在线观看 | 久久久久99精品成人片 | 成人一在线视频日韩国产 | 伊人久久大香线蕉av一区二区 | 国产亚av手机在线观看 | 我要看www免费看插插视频 | www国产亚洲精品久久久日本 | 国产激情综合五月久久 | 欧洲熟妇精品视频 | 久久久久久亚洲精品a片成人 | 国产亚洲人成a在线v网站 | 在线播放亚洲第一字幕 | 无码人妻丰满熟妇区毛片18 | 久久亚洲精品中文字幕无男同 | 亚洲毛片av日韩av无码 | 99久久99久久免费精品蜜桃 | 中文久久乱码一区二区 | 欧美一区二区三区视频在线观看 | 国产综合色产在线精品 | аⅴ资源天堂资源库在线 | 最新版天堂资源中文官网 | 久久久www成人免费毛片 | 88国产精品欧美一区二区三区 | 久久天天躁夜夜躁狠狠 | 老司机亚洲精品影院无码 | 欧美老妇交乱视频在线观看 | 纯爱无遮挡h肉动漫在线播放 | 久久无码专区国产精品s | 久久无码人妻影院 | 又大又紧又粉嫩18p少妇 | 日韩欧美群交p片內射中文 | 偷窥村妇洗澡毛毛多 | 亚洲欧美国产精品久久 | 国产精品人妻一区二区三区四 | 中文精品久久久久人妻不卡 | 久久精品成人欧美大片 | 日本大香伊一区二区三区 | 最近的中文字幕在线看视频 | 国内精品人妻无码久久久影院蜜桃 | 中文字幕乱码亚洲无线三区 | 欧美黑人性暴力猛交喷水 | 亚洲精品国产精品乱码视色 | 风流少妇按摩来高潮 | 秋霞成人午夜鲁丝一区二区三区 | 欧美日韩一区二区三区自拍 | 亚洲精品国产精品乱码不卡 | 亚洲精品综合一区二区三区在线 | 国产激情艳情在线看视频 | 玩弄人妻少妇500系列视频 | 纯爱无遮挡h肉动漫在线播放 | 成 人 免费观看网站 | 欧美丰满熟妇xxxx性ppx人交 | 国内揄拍国内精品少妇国语 | 成人一区二区免费视频 | 久久久久99精品国产片 | 日本精品人妻无码77777 天堂一区人妻无码 | 国产精品毛片一区二区 | 人妻无码久久精品人妻 | 人人妻人人澡人人爽人人精品浪潮 | 男女爱爱好爽视频免费看 | 澳门永久av免费网站 | 国产色视频一区二区三区 | 亚洲综合色区中文字幕 | 精品久久久无码人妻字幂 | 蜜桃无码一区二区三区 | 夜夜高潮次次欢爽av女 | 88国产精品欧美一区二区三区 | 久久久久成人精品免费播放动漫 | 国产精品自产拍在线观看 | 色婷婷综合中文久久一本 | 一本色道久久综合狠狠躁 | 无码播放一区二区三区 | 老头边吃奶边弄进去呻吟 | 国产激情综合五月久久 | 精品久久久中文字幕人妻 | 亚洲色无码一区二区三区 | 国产激情精品一区二区三区 | 成人性做爰aaa片免费看 | 久久综合色之久久综合 | 成人欧美一区二区三区黑人免费 | 精品国产一区二区三区四区 | 欧美丰满老熟妇xxxxx性 | 国产xxx69麻豆国语对白 | 青青青手机频在线观看 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 大屁股大乳丰满人妻 | 亚洲精品一区二区三区在线观看 | 亚洲伊人久久精品影院 | 奇米影视888欧美在线观看 | 99国产精品白浆在线观看免费 | 无码国产激情在线观看 | 久久精品人人做人人综合试看 | 中文字幕精品av一区二区五区 | 人人澡人摸人人添 | 国产精品久久久久久亚洲毛片 | 丰满少妇高潮惨叫视频 | 日本护士xxxxhd少妇 | 色综合久久久久综合一本到桃花网 | 久久精品女人天堂av免费观看 | 日韩人妻少妇一区二区三区 | 曰本女人与公拘交酡免费视频 | 亚洲精品一区二区三区在线 | 国产精品a成v人在线播放 | 久久综合网欧美色妞网 | 亚洲狠狠色丁香婷婷综合 | 亚洲天堂2017无码中文 | 亚洲精品欧美二区三区中文字幕 | 天干天干啦夜天干天2017 | 欧美乱妇无乱码大黄a片 | 亚洲精品一区二区三区婷婷月 | 51国偷自产一区二区三区 | 在线观看国产午夜福利片 | 久久99精品国产麻豆 | 麻豆果冻传媒2021精品传媒一区下载 | 在线a亚洲视频播放在线观看 | 无码午夜成人1000部免费视频 | 午夜精品一区二区三区在线观看 | 77777熟女视频在线观看 а天堂中文在线官网 | 在线播放亚洲第一字幕 | 99国产欧美久久久精品 | 狠狠色欧美亚洲狠狠色www | 天海翼激烈高潮到腰振不止 | 欧美成人高清在线播放 | 国产精品-区区久久久狼 | 久久久精品欧美一区二区免费 | 亚洲日本va午夜在线电影 | 77777熟女视频在线观看 а天堂中文在线官网 | 99在线 | 亚洲 | 国产另类ts人妖一区二区 | 搡女人真爽免费视频大全 | 国产色在线 | 国产 | 熟女俱乐部五十路六十路av | 欧美日韩色另类综合 | 国产97人人超碰caoprom | 一本久久a久久精品vr综合 | 国产精品久久久久久无码 | 国产精品高潮呻吟av久久 | 97夜夜澡人人双人人人喊 | 免费播放一区二区三区 | 亚洲国产精品一区二区美利坚 | 青青青爽视频在线观看 | 国产极品美女高潮无套在线观看 | 在线看片无码永久免费视频 | 久久99精品国产麻豆 | 无码人妻出轨黑人中文字幕 | 国产av一区二区精品久久凹凸 | 内射巨臀欧美在线视频 | 久久国产精品精品国产色婷婷 | 丰满人妻精品国产99aⅴ | 中文字幕av伊人av无码av | 丰满人妻精品国产99aⅴ | 国产九九九九九九九a片 | 丝袜 中出 制服 人妻 美腿 | 国产手机在线αⅴ片无码观看 | 国产特级毛片aaaaaa高潮流水 | 亚洲成在人网站无码天堂 | 免费播放一区二区三区 | 人妻少妇被猛烈进入中文字幕 | 精品人妻av区 | 国产亚洲精品久久久闺蜜 | 撕开奶罩揉吮奶头视频 | 国产成人精品优优av | 国产av一区二区三区最新精品 | 樱花草在线社区www | 国产极品视觉盛宴 | 任你躁在线精品免费 | 成人片黄网站色大片免费观看 | 国产乡下妇女做爰 | 国产sm调教视频在线观看 | 国产九九九九九九九a片 | 无码人妻出轨黑人中文字幕 | 亚洲精品久久久久中文第一幕 | 黄网在线观看免费网站 | 偷窥村妇洗澡毛毛多 | yw尤物av无码国产在线观看 | 中文字幕无码乱人伦 | 日韩精品成人一区二区三区 | 精品久久久无码中文字幕 | 午夜时刻免费入口 | 色一情一乱一伦一区二区三欧美 | 极品嫩模高潮叫床 | 国产精品办公室沙发 | 国产欧美亚洲精品a | 久久久精品欧美一区二区免费 | 亚洲精品一区二区三区大桥未久 | 好男人www社区 | 麻豆av传媒蜜桃天美传媒 | 丰腴饱满的极品熟妇 | 成年美女黄网站色大免费全看 | 国产网红无码精品视频 | 亚洲一区二区三区香蕉 | 丰满肥臀大屁股熟妇激情视频 | 天天摸天天碰天天添 | 丰满妇女强制高潮18xxxx | 日日摸天天摸爽爽狠狠97 | 中文毛片无遮挡高清免费 | 国产精品久久久av久久久 | 国产口爆吞精在线视频 | 亚洲天堂2017无码 | 六十路熟妇乱子伦 | 高清无码午夜福利视频 | 亚洲人成无码网www | 2020久久超碰国产精品最新 | 九月婷婷人人澡人人添人人爽 | 日韩精品乱码av一区二区 | 欧美激情综合亚洲一二区 | 国产精品二区一区二区aⅴ污介绍 | 在线观看免费人成视频 | 一本久久a久久精品亚洲 | 亚洲日韩av一区二区三区中文 | 狠狠色色综合网站 | 无码人妻出轨黑人中文字幕 | 天堂一区人妻无码 | 97资源共享在线视频 | 亲嘴扒胸摸屁股激烈网站 | 一本大道久久东京热无码av | 久久人人97超碰a片精品 | 大乳丰满人妻中文字幕日本 | 国产色精品久久人妻 | 国产精品二区一区二区aⅴ污介绍 | 亚洲综合在线一区二区三区 | 亚洲色大成网站www国产 | 波多野42部无码喷潮在线 | 色情久久久av熟女人妻网站 | 东北女人啪啪对白 | 欧美xxxx黑人又粗又长 | 一本色道婷婷久久欧美 | 久久久无码中文字幕久... | 中文精品无码中文字幕无码专区 | 伊人色综合久久天天小片 | 色综合久久久久综合一本到桃花网 | 国产又粗又硬又大爽黄老大爷视 | 精品无码av一区二区三区 | 国产精品久久久久久亚洲毛片 | 桃花色综合影院 | 国产av一区二区精品久久凹凸 | 日日噜噜噜噜夜夜爽亚洲精品 | 欧美成人免费全部网站 | 欧美变态另类xxxx | 久久久久久国产精品无码下载 | 国产午夜无码精品免费看 | 亚洲中文字幕乱码av波多ji | 国产性生大片免费观看性 | 色婷婷欧美在线播放内射 | 中文字幕无码免费久久9一区9 | 久久精品国产精品国产精品污 | 久久无码专区国产精品s | 99久久人妻精品免费二区 | 国产欧美亚洲精品a | 狠狠色色综合网站 | 国语精品一区二区三区 | 国产无遮挡又黄又爽又色 | 人妻有码中文字幕在线 | 亚洲日韩精品欧美一区二区 | 日韩精品成人一区二区三区 | 亚洲综合伊人久久大杳蕉 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲伊人久久精品影院 | 人妻有码中文字幕在线 | 亚洲国产日韩a在线播放 | 国内少妇偷人精品视频 | √天堂中文官网8在线 | 色情久久久av熟女人妻网站 | 激情五月综合色婷婷一区二区 | 丰满诱人的人妻3 | 亚洲精品国偷拍自产在线观看蜜桃 | 无人区乱码一区二区三区 | 性欧美牲交在线视频 | 国产精品久久久一区二区三区 | 美女黄网站人色视频免费国产 | 国产麻豆精品精东影业av网站 | 国产精品.xx视频.xxtv | 亚洲成在人网站无码天堂 | av无码不卡在线观看免费 | 桃花色综合影院 | 久热国产vs视频在线观看 | av香港经典三级级 在线 | 久久熟妇人妻午夜寂寞影院 | 久久亚洲国产成人精品性色 | 大屁股大乳丰满人妻 | 欧美人与禽zoz0性伦交 | 女人和拘做爰正片视频 | 丰满肥臀大屁股熟妇激情视频 | www国产亚洲精品久久久日本 | 国产综合色产在线精品 | 精品国偷自产在线 | 国产香蕉尹人视频在线 | 国产成人精品必看 | 国产成人av免费观看 | 成人精品天堂一区二区三区 | 国产精品对白交换视频 | 免费播放一区二区三区 | 国产精品毛片一区二区 | 18精品久久久无码午夜福利 | 久久人人爽人人爽人人片av高清 | 少妇太爽了在线观看 | 亚洲国产欧美在线成人 | 国产人妻精品一区二区三区不卡 | 日本爽爽爽爽爽爽在线观看免 | 国产精品办公室沙发 | 久久国产精品精品国产色婷婷 | 97久久精品无码一区二区 | 亚洲精品久久久久久一区二区 | 久久精品一区二区三区四区 | 最新国产麻豆aⅴ精品无码 | 日本高清一区免费中文视频 | 亚洲国产日韩a在线播放 | 国产精品99久久精品爆乳 | 亚洲自偷自偷在线制服 | 国产精品内射视频免费 | 亚洲乱亚洲乱妇50p | 欧美人与物videos另类 | 中文字幕+乱码+中文字幕一区 | 最近中文2019字幕第二页 | 欧美 日韩 亚洲 在线 | 久久综合给合久久狠狠狠97色 | 亚洲自偷精品视频自拍 | 99精品无人区乱码1区2区3区 | 国精产品一品二品国精品69xx | 98国产精品综合一区二区三区 | 亚洲人成网站色7799 | 亚洲 日韩 欧美 成人 在线观看 | www一区二区www免费 | 亚洲高清偷拍一区二区三区 | 久久久久久亚洲精品a片成人 | 乌克兰少妇性做爰 | 国产精品久久国产三级国 | 在线欧美精品一区二区三区 | 四虎国产精品一区二区 | 2019nv天堂香蕉在线观看 | 日欧一片内射va在线影院 | 成人亚洲精品久久久久软件 | 久久精品中文闷骚内射 | 成人欧美一区二区三区黑人免费 | 亚洲精品国产第一综合99久久 | 国内精品久久毛片一区二区 | 在线观看欧美一区二区三区 | av小次郎收藏 | 国产偷抇久久精品a片69 | 老司机亚洲精品影院 | 国产精品无码mv在线观看 | 在线观看国产一区二区三区 | 天天av天天av天天透 | 亚洲日韩av一区二区三区四区 | 亚洲熟妇色xxxxx欧美老妇 | 精品偷拍一区二区三区在线看 | 风流少妇按摩来高潮 | 亚洲爆乳精品无码一区二区三区 | 欧美性色19p | 荫蒂添的好舒服视频囗交 | 亚洲精品中文字幕乱码 | аⅴ资源天堂资源库在线 | 国产人成高清在线视频99最全资源 | 亚洲伊人久久精品影院 | 色一情一乱一伦一视频免费看 | 国产农村乱对白刺激视频 | 中文字幕无码免费久久9一区9 | 成人免费无码大片a毛片 | 永久免费精品精品永久-夜色 | 亚洲国产精品久久久天堂 | 波多野结衣av在线观看 | 成人影院yy111111在线观看 | 国内精品久久久久久中文字幕 | 国产99久久精品一区二区 | 久久久av男人的天堂 | 免费观看又污又黄的网站 | 国产美女极度色诱视频www | 中文无码伦av中文字幕 | 人人爽人人澡人人高潮 | 女人被男人爽到呻吟的视频 | 国产欧美精品一区二区三区 | 欧美日本免费一区二区三区 | 夜夜夜高潮夜夜爽夜夜爰爰 | 亚洲理论电影在线观看 | 99久久久无码国产aaa精品 | 亚洲精品无码人妻无码 | 久久综合激激的五月天 | av在线亚洲欧洲日产一区二区 | 欧美亚洲国产一区二区三区 | 麻豆国产丝袜白领秘书在线观看 | 日产精品99久久久久久 | 内射巨臀欧美在线视频 | 欧洲精品码一区二区三区免费看 | 亚洲熟女一区二区三区 | 在线观看欧美一区二区三区 | 狠狠色欧美亚洲狠狠色www | 亚洲精品国偷拍自产在线观看蜜桃 | 国产成人精品无码播放 | 国产精品无码一区二区三区不卡 | 欧美激情综合亚洲一二区 | 好屌草这里只有精品 | 国产精品欧美成人 | 成人欧美一区二区三区 | 亚洲欧美国产精品专区久久 | 无码精品国产va在线观看dvd | 国产av一区二区精品久久凹凸 | 偷窥日本少妇撒尿chinese | 鲁鲁鲁爽爽爽在线视频观看 | 波多野结衣av一区二区全免费观看 | 国产精品人人爽人人做我的可爱 | 日日摸夜夜摸狠狠摸婷婷 | 欧美人与物videos另类 | 人人澡人人妻人人爽人人蜜桃 | 少妇人妻偷人精品无码视频 | 人人爽人人澡人人高潮 | 300部国产真实乱 | 嫩b人妻精品一区二区三区 | 乱码午夜-极国产极内射 | 欧美日韩一区二区综合 | 国产口爆吞精在线视频 | 亚洲成在人网站无码天堂 | 无码毛片视频一区二区本码 | 国产亚洲人成在线播放 | 欧美高清在线精品一区 | 国产精品久久久久无码av色戒 | 麻豆md0077饥渴少妇 | 九一九色国产 | 精品偷拍一区二区三区在线看 | 欧美 日韩 亚洲 在线 | 1000部夫妻午夜免费 | 日本熟妇人妻xxxxx人hd | 亚洲国产成人av在线观看 | 国产农村乱对白刺激视频 | 久久97精品久久久久久久不卡 | 久久久成人毛片无码 | 牲交欧美兽交欧美 | 精品国产av色一区二区深夜久久 | 精品无码av一区二区三区 | 国产成人久久精品流白浆 | 国产明星裸体无码xxxx视频 | 国产香蕉97碰碰久久人人 | 一区二区传媒有限公司 | 国产精品成人av在线观看 | 欧美 丝袜 自拍 制服 另类 | 中文字幕乱妇无码av在线 | 中文字幕av无码一区二区三区电影 | 乱人伦人妻中文字幕无码 | 男人的天堂av网站 | 久久综合香蕉国产蜜臀av | 国内精品一区二区三区不卡 | 人妻夜夜爽天天爽三区 | 国产精品-区区久久久狼 | 国产亚洲视频中文字幕97精品 | 十八禁视频网站在线观看 | 内射白嫩少妇超碰 | 中文字幕+乱码+中文字幕一区 | 亚洲乱码国产乱码精品精 | 成人无码精品1区2区3区免费看 | 爽爽影院免费观看 | 永久免费观看国产裸体美女 | 人妻无码久久精品人妻 | 野外少妇愉情中文字幕 | 国产精品内射视频免费 | 久久综合给合久久狠狠狠97色 | 亚洲熟女一区二区三区 | 久久综合激激的五月天 | 亚洲精品成a人在线观看 | 国产亚洲美女精品久久久2020 | 国产亚洲精品久久久ai换 | 亚洲 日韩 欧美 成人 在线观看 | 97久久超碰中文字幕 | 中文字幕无码热在线视频 | 强伦人妻一区二区三区视频18 | 中文字幕无码免费久久99 | 日产精品99久久久久久 | 中文字幕乱码亚洲无线三区 | 丁香花在线影院观看在线播放 | 中文字幕无码av激情不卡 | 76少妇精品导航 | 欧美性生交xxxxx久久久 | 女人高潮内射99精品 | 蜜臀aⅴ国产精品久久久国产老师 | 男女爱爱好爽视频免费看 | 日本免费一区二区三区最新 | 亚洲日韩中文字幕在线播放 | 在线播放亚洲第一字幕 | 嫩b人妻精品一区二区三区 | 日韩人妻少妇一区二区三区 | 丰满人妻翻云覆雨呻吟视频 | 大胆欧美熟妇xx | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 久久午夜无码鲁丝片午夜精品 | 少妇一晚三次一区二区三区 | 国产精品久久久久9999小说 | 精品国产精品久久一区免费式 | 久久99国产综合精品 | 久久亚洲精品中文字幕无男同 | 5858s亚洲色大成网站www | 天天躁夜夜躁狠狠是什么心态 | 国产婷婷色一区二区三区在线 | 亚洲 另类 在线 欧美 制服 | 国产免费无码一区二区视频 | 国产美女精品一区二区三区 | 日韩少妇白浆无码系列 | 日韩 欧美 动漫 国产 制服 | 97久久精品无码一区二区 | 日本免费一区二区三区最新 | 亚洲一区二区三区含羞草 | 扒开双腿吃奶呻吟做受视频 | 内射爽无广熟女亚洲 | 在教室伦流澡到高潮hnp视频 | 欧美熟妇另类久久久久久不卡 | 国产亚洲精品久久久久久久 | 成人影院yy111111在线观看 | 国精产品一区二区三区 | 国产乡下妇女做爰 | 免费无码肉片在线观看 | 色 综合 欧美 亚洲 国产 | 六十路熟妇乱子伦 | 性做久久久久久久久 | 女高中生第一次破苞av | 亚洲阿v天堂在线 | 鲁大师影院在线观看 | 亚洲精品久久久久久久久久久 | 国产精品亚洲综合色区韩国 | 国产精品免费大片 | 中文精品无码中文字幕无码专区 | 少妇人妻大乳在线视频 | 国产福利视频一区二区 | 久久精品中文字幕一区 | 久久久久99精品成人片 | 午夜福利不卡在线视频 | 色婷婷综合中文久久一本 | 午夜福利一区二区三区在线观看 | 亚洲乱码国产乱码精品精 | 亚洲精品一区二区三区在线 | 久久久久成人片免费观看蜜芽 | 午夜精品一区二区三区在线观看 | 少妇人妻大乳在线视频 | 300部国产真实乱 | 国产激情无码一区二区app | 日本大乳高潮视频在线观看 | 国产一精品一av一免费 | 大屁股大乳丰满人妻 | 日本xxxx色视频在线观看免费 | 久久久久免费看成人影片 | 三级4级全黄60分钟 | 国产做国产爱免费视频 | 精品一二三区久久aaa片 | 亚洲综合无码久久精品综合 | 日韩精品一区二区av在线 | 正在播放东北夫妻内射 | aⅴ在线视频男人的天堂 | 一区二区传媒有限公司 | 午夜免费福利小电影 | 国产精品亚洲专区无码不卡 | 日本免费一区二区三区最新 | 国产精品久久久久影院嫩草 | 永久免费精品精品永久-夜色 | 俺去俺来也在线www色官网 | 久久www免费人成人片 | 成人无码影片精品久久久 | 久久久精品成人免费观看 | 一本色道久久综合亚洲精品不卡 | 久久成人a毛片免费观看网站 | 国产婷婷色一区二区三区在线 | 高清国产亚洲精品自在久久 | 中文字幕av伊人av无码av | 国产精品久久久久9999小说 | 久久精品国产一区二区三区 | а√资源新版在线天堂 | 欧美真人作爱免费视频 | 一本大道伊人av久久综合 | 一本久道久久综合狠狠爱 | 欧美熟妇另类久久久久久不卡 | 国产精品亚洲综合色区韩国 | 无码av岛国片在线播放 | 亚洲国产精品无码一区二区三区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产猛烈高潮尖叫视频免费 | 日本一卡二卡不卡视频查询 | 中国女人内谢69xxxx | 又湿又紧又大又爽a视频国产 | 日本一卡2卡3卡四卡精品网站 | www国产亚洲精品久久久日本 | 国产精品自产拍在线观看 | 18无码粉嫩小泬无套在线观看 | 免费人成在线观看网站 | 日韩成人一区二区三区在线观看 | 亚洲一区av无码专区在线观看 | 300部国产真实乱 | 女人被爽到呻吟gif动态图视看 | 亚洲欧美日韩综合久久久 | 欧美freesex黑人又粗又大 | 18无码粉嫩小泬无套在线观看 | 久久国产精品精品国产色婷婷 | 久久精品国产一区二区三区肥胖 | 亚洲aⅴ无码成人网站国产app | 99久久精品无码一区二区毛片 | 国产一区二区三区日韩精品 | 伊人久久大香线蕉午夜 | 久久成人a毛片免费观看网站 | 正在播放老肥熟妇露脸 | 玩弄人妻少妇500系列视频 | 极品嫩模高潮叫床 | 人人妻在人人 | 久久久久成人片免费观看蜜芽 | 亚洲精品美女久久久久久久 | 乌克兰少妇性做爰 | 色欲av亚洲一区无码少妇 | 日日摸天天摸爽爽狠狠97 | 99精品国产综合久久久久五月天 | 日产精品99久久久久久 | 婷婷六月久久综合丁香 | 国产在线无码精品电影网 | 久久久久亚洲精品男人的天堂 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 东京热男人av天堂 | 婷婷丁香六月激情综合啪 | 西西人体www44rt大胆高清 | 色婷婷欧美在线播放内射 | 亚洲精品久久久久中文第一幕 | 麻豆蜜桃av蜜臀av色欲av | 精品国产精品久久一区免费式 | 成人性做爰aaa片免费看 | 麻豆果冻传媒2021精品传媒一区下载 | 精品国精品国产自在久国产87 | 夜夜躁日日躁狠狠久久av | 国产福利视频一区二区 | 色综合视频一区二区三区 | 无套内谢的新婚少妇国语播放 | 国产在线精品一区二区高清不卡 | 日日鲁鲁鲁夜夜爽爽狠狠 | 激情国产av做激情国产爱 | 国产成人无码一二三区视频 | 黑人粗大猛烈进出高潮视频 | 欧美喷潮久久久xxxxx | 在线观看国产午夜福利片 | av香港经典三级级 在线 | 国产熟妇另类久久久久 | 亚洲人交乣女bbw | 久久熟妇人妻午夜寂寞影院 | 四十如虎的丰满熟妇啪啪 | 亚洲国产精品久久久久久 | 中文字幕无码av波多野吉衣 | 超碰97人人射妻 | 成熟女人特级毛片www免费 | 国产又爽又猛又粗的视频a片 | 成人免费无码大片a毛片 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 亚洲日韩av一区二区三区四区 | 露脸叫床粗话东北少妇 | 国产午夜福利亚洲第一 | 日本www一道久久久免费榴莲 | 欧美一区二区三区 | 亚洲人成影院在线观看 | 成人三级无码视频在线观看 | 色综合久久久久综合一本到桃花网 | 麻豆精品国产精华精华液好用吗 | 国产精品.xx视频.xxtv | 日本大香伊一区二区三区 | 国产精品福利视频导航 | 九月婷婷人人澡人人添人人爽 | 大肉大捧一进一出好爽视频 | 老太婆性杂交欧美肥老太 | 大胆欧美熟妇xx | 大乳丰满人妻中文字幕日本 | 3d动漫精品啪啪一区二区中 | 亚洲精品一区二区三区在线 | 青青草原综合久久大伊人精品 | 欧美午夜特黄aaaaaa片 | 人妻与老人中文字幕 | 久在线观看福利视频 | 国精产品一区二区三区 | 国产综合色产在线精品 | 色综合视频一区二区三区 | 中文字幕乱妇无码av在线 | 55夜色66夜色国产精品视频 | 台湾无码一区二区 | 欧美兽交xxxx×视频 | 99视频精品全部免费免费观看 | 国产午夜福利100集发布 | 成人无码影片精品久久久 | 无码av免费一区二区三区试看 | 欧美丰满少妇xxxx性 | 欧美成人高清在线播放 | 欧美成人午夜精品久久久 | 欧美 丝袜 自拍 制服 另类 | 亚洲色大成网站www | 欧洲精品码一区二区三区免费看 | 精品国精品国产自在久国产87 | 好爽又高潮了毛片免费下载 | 亚洲一区二区三区含羞草 | 中文字幕无码免费久久99 | 无码中文字幕色专区 | 精品国产福利一区二区 | 偷窥村妇洗澡毛毛多 | 男女下面进入的视频免费午夜 | 帮老师解开蕾丝奶罩吸乳网站 | 国产无遮挡又黄又爽又色 | 成人三级无码视频在线观看 | 99国产欧美久久久精品 | 5858s亚洲色大成网站www | 国产乱子伦视频在线播放 | 色综合久久中文娱乐网 | 强奷人妻日本中文字幕 | 天干天干啦夜天干天2017 | 欧美老人巨大xxxx做受 | 亚洲精品久久久久中文第一幕 | 国产又爽又黄又刺激的视频 | 97资源共享在线视频 | 亚洲熟妇色xxxxx欧美老妇y | 99精品无人区乱码1区2区3区 | 蜜桃av抽搐高潮一区二区 | 国产亚洲精品精品国产亚洲综合 | 亚洲の无码国产の无码步美 | 亚洲の无码国产の无码步美 | 亚洲乱亚洲乱妇50p | 国产精品久久久av久久久 | 亚洲小说图区综合在线 | 色综合天天综合狠狠爱 | 亚洲一区二区三区在线观看网站 | 欧美性生交xxxxx久久久 | 免费无码的av片在线观看 | 蜜臀aⅴ国产精品久久久国产老师 | 老熟妇仑乱视频一区二区 | 欧美精品免费观看二区 | 亚洲欧美中文字幕5发布 | 国产精品久久久久9999小说 | 国产午夜视频在线观看 | 人人妻人人藻人人爽欧美一区 | 牲欲强的熟妇农村老妇女视频 | 久久亚洲a片com人成 | 亚洲综合伊人久久大杳蕉 | 青青青手机频在线观看 | 一本久道高清无码视频 | 国产九九九九九九九a片 | 国産精品久久久久久久 | 人妻天天爽夜夜爽一区二区 | 国内精品久久毛片一区二区 | 乌克兰少妇性做爰 | 久久伊人色av天堂九九小黄鸭 | 亚洲精品成人福利网站 | 东京无码熟妇人妻av在线网址 | 久久精品国产一区二区三区 | 日韩视频 中文字幕 视频一区 | 亚洲精品一区二区三区婷婷月 | 欧美日韩综合一区二区三区 | 东京热无码av男人的天堂 | 无码纯肉视频在线观看 | 精品无码国产自产拍在线观看蜜 | 欧美日韩综合一区二区三区 | 亚洲精品无码人妻无码 | 亚洲国产成人a精品不卡在线 | 妺妺窝人体色www在线小说 | 国产精品久久精品三级 | 一本大道伊人av久久综合 | 国产色视频一区二区三区 | 日韩无套无码精品 | 青青草原综合久久大伊人精品 | 免费无码的av片在线观看 | 中文毛片无遮挡高清免费 | 3d动漫精品啪啪一区二区中 | 亚洲精品一区二区三区婷婷月 | 午夜丰满少妇性开放视频 | 久久久www成人免费毛片 | 国产精品多人p群无码 | 国产小呦泬泬99精品 | 中文字幕乱码亚洲无线三区 | 精品久久久中文字幕人妻 | 久久精品国产一区二区三区肥胖 | 中文精品无码中文字幕无码专区 | 欧美xxxxx精品 | 久久精品国产大片免费观看 | 乌克兰少妇性做爰 | 成人无码精品一区二区三区 | 红桃av一区二区三区在线无码av | 九月婷婷人人澡人人添人人爽 | 伊人色综合久久天天小片 | 最新国产乱人伦偷精品免费网站 | 全黄性性激高免费视频 | 久久久久免费精品国产 | 曰韩无码二三区中文字幕 | 亚洲乱码国产乱码精品精 | 中文毛片无遮挡高清免费 | 亚洲中文字幕乱码av波多ji | av在线亚洲欧洲日产一区二区 | 精品欧洲av无码一区二区三区 | 成人免费视频视频在线观看 免费 | 人妻体内射精一区二区三四 | 少妇人妻偷人精品无码视频 | 亚洲国产成人a精品不卡在线 | 成人欧美一区二区三区黑人免费 | 婷婷五月综合激情中文字幕 | 在线成人www免费观看视频 | 亚洲色偷偷男人的天堂 | 极品嫩模高潮叫床 | 亚洲中文字幕无码中字 | 四虎国产精品一区二区 | 搡女人真爽免费视频大全 | 亚洲精品国产第一综合99久久 | 无码人妻黑人中文字幕 | 男女下面进入的视频免费午夜 | 欧美精品免费观看二区 | 澳门永久av免费网站 | 最近的中文字幕在线看视频 | 亚洲中文字幕乱码av波多ji | 国产后入清纯学生妹 | 性色欲情网站iwww九文堂 | 装睡被陌生人摸出水好爽 | 精品人妻中文字幕有码在线 | 国产精品久久久久影院嫩草 | 国内综合精品午夜久久资源 | a在线亚洲男人的天堂 | 麻豆国产人妻欲求不满 | 老司机亚洲精品影院无码 | 牲欲强的熟妇农村老妇女视频 | 狠狠色欧美亚洲狠狠色www | 免费国产黄网站在线观看 | 亚洲欧美精品aaaaaa片 | 欧美熟妇另类久久久久久不卡 | 久久久精品成人免费观看 | 亚洲 欧美 激情 小说 另类 | 日本熟妇大屁股人妻 | 国产精品永久免费视频 | 午夜精品一区二区三区在线观看 | 欧美日韩一区二区免费视频 | 亚洲一区二区三区在线观看网站 | 精品夜夜澡人妻无码av蜜桃 | 国产两女互慰高潮视频在线观看 | 国产亚洲tv在线观看 | 亚洲狠狠色丁香婷婷综合 | 国产精品久久久久久久9999 | 色窝窝无码一区二区三区色欲 | 亚洲中文字幕乱码av波多ji | 老司机亚洲精品影院 | 国产小呦泬泬99精品 | 亚拍精品一区二区三区探花 | 国产一区二区三区四区五区加勒比 | 亚洲中文字幕va福利 | 国产精品永久免费视频 | 98国产精品综合一区二区三区 | 亚洲性无码av中文字幕 | 精品亚洲成av人在线观看 | 美女黄网站人色视频免费国产 | 久久亚洲精品成人无码 | 久久久中文久久久无码 | 久久久久免费精品国产 | 超碰97人人射妻 | 人人爽人人爽人人片av亚洲 | 久久 国产 尿 小便 嘘嘘 | 亚洲天堂2017无码 | 激情爆乳一区二区三区 | 日本爽爽爽爽爽爽在线观看免 | 亚洲精品久久久久avwww潮水 | 国产精品人人爽人人做我的可爱 | 99久久99久久免费精品蜜桃 | 亚洲 a v无 码免 费 成 人 a v | 国产97在线 | 亚洲 | 欧美精品一区二区精品久久 | 久久婷婷五月综合色国产香蕉 | 最新版天堂资源中文官网 | 美女极度色诱视频国产 | 亚洲国产高清在线观看视频 | 国产成人无码一二三区视频 | 99视频精品全部免费免费观看 | 国产精品久久久久9999小说 | 国产精品美女久久久网av | 免费无码的av片在线观看 | 国产精品久久福利网站 | 熟妇人妻无码xxx视频 | 国产精品无套呻吟在线 | 67194成是人免费无码 | 老熟女重囗味hdxx69 | 波多野结衣av一区二区全免费观看 | 在线播放免费人成毛片乱码 | 免费观看又污又黄的网站 | 日韩成人一区二区三区在线观看 | 人妻体内射精一区二区三四 | 狠狠色欧美亚洲狠狠色www | 波多野结衣av一区二区全免费观看 | 国产精品手机免费 | 97资源共享在线视频 | 女人高潮内射99精品 | 亚洲熟悉妇女xxx妇女av | 亚洲色偷偷男人的天堂 | 国产国产精品人在线视 | 波多野结衣 黑人 | 亚洲成a人片在线观看无码3d | 黑人玩弄人妻中文在线 | 国产人妻精品午夜福利免费 | 无码福利日韩神码福利片 | 国产一区二区三区日韩精品 | 精品国精品国产自在久国产87 | 国产精品丝袜黑色高跟鞋 | 熟妇人妻激情偷爽文 | 午夜精品一区二区三区的区别 | 老熟妇乱子伦牲交视频 | 国产乱人无码伦av在线a | 亚洲爆乳大丰满无码专区 | 无遮挡啪啪摇乳动态图 | 中文字幕av日韩精品一区二区 | 亚洲理论电影在线观看 | www成人国产高清内射 | 日韩精品一区二区av在线 | 国产精品无码mv在线观看 | 九九久久精品国产免费看小说 | 欧美黑人乱大交 | 人人妻人人澡人人爽欧美一区九九 | 老子影院午夜伦不卡 | 亚洲国产一区二区三区在线观看 | 天天摸天天透天天添 | 日本欧美一区二区三区乱码 | a在线亚洲男人的天堂 | 天下第一社区视频www日本 | www成人国产高清内射 | 亚洲精品国产a久久久久久 | 中文字幕无码日韩专区 | 国产午夜福利亚洲第一 | 狠狠cao日日穞夜夜穞av | 免费看男女做好爽好硬视频 | 久久综合香蕉国产蜜臀av | 欧美日韩综合一区二区三区 | 亚洲国产精品一区二区美利坚 | 麻豆国产人妻欲求不满 | 欧美日本免费一区二区三区 | 一个人看的www免费视频在线观看 | 无码毛片视频一区二区本码 | 欧美兽交xxxx×视频 | 在线精品国产一区二区三区 | 老熟妇仑乱视频一区二区 | 久久久精品人妻久久影视 | 九九久久精品国产免费看小说 | 我要看www免费看插插视频 | 丰满人妻一区二区三区免费视频 | 性色欲网站人妻丰满中文久久不卡 | 国产真人无遮挡作爱免费视频 | 国色天香社区在线视频 | 亚洲一区二区三区无码久久 | 乱人伦人妻中文字幕无码久久网 | 久久午夜夜伦鲁鲁片无码免费 | 性色av无码免费一区二区三区 | 欧美大屁股xxxxhd黑色 | 国产乱码精品一品二品 | 丝袜人妻一区二区三区 | 无码国产乱人伦偷精品视频 | 国产香蕉尹人视频在线 | 亚洲欧美精品伊人久久 | 人妻aⅴ无码一区二区三区 | 性生交片免费无码看人 | 中文无码成人免费视频在线观看 | 精品成在人线av无码免费看 | 午夜精品一区二区三区的区别 | 对白脏话肉麻粗话av | 中文字幕精品av一区二区五区 | 少妇高潮一区二区三区99 | 亚洲va欧美va天堂v国产综合 | 亚洲小说春色综合另类 | 亚洲欧洲日本综合aⅴ在线 | 精品国偷自产在线视频 | 久久精品视频在线看15 | 欧美精品国产综合久久 | 国产精品人妻一区二区三区四 | 日本爽爽爽爽爽爽在线观看免 |