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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

GCD 深入理解:第一部分

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

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

原作者:Derek Selander

譯者:@nixzhu

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

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

什么是 GCD

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

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

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

GCD 術(shù)語

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

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

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

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

Synchronous vs. Asynchronous 同步 vs. 異步

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

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

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

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

Critical Section 臨界區(qū)

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

Race Condition 競態(tài)條件

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

Deadlock 死鎖

兩個(gè)(有時(shí)更多)東西——在大多數(shù)情況下,是線程——所謂的死鎖是指它們都卡住了,并等待對方完成或執(zhí)行其它操作。第一個(gè)不能完成是因?yàn)樗诘却诙€(gè)的完成。但第二個(gè)也不能完成,因?yàn)樗诘却谝粋€(gè)的完成。

Thread Safe 線程安全

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

Context Switch 上下文切換

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

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

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

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

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

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

Queues 隊(duì)列

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

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

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

Serial Queues 串行隊(duì)列

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

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

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

Concurrent Queues 并發(fā)隊(duì)列

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

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

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

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

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

Queue Types 隊(duì)列類型

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

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

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

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

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

入門

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

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

點(diǎn)擊此處下載項(xiàng)目

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

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

這個(gè)項(xiàng)目中有四個(gè)有趣的類:

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

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

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

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

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

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

打開?PhotoDetailViewController?并用下面的實(shí)現(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});}); }

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

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

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

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

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

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

    使用 dispatch_after 延后工作

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

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

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

    添加如下代碼到到 PhotoCollectionViewController.m 中 showOrHideNavPrompt 的廢止實(shí)現(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í)候。按照注釋數(shù)字順序看看:

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

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

    不知道何時(shí)適合使用?dispatch_after??

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

    讓你的單例線程安全

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

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

    單例的線程擔(dān)憂范圍從初始化開始,到信息的讀和寫。PhotoManager?類被實(shí)現(xiàn)為單例——它在目前的狀態(tài)下就會被這些問題所困擾。要看看事情如何很快地失去控制,你將在單例實(shí)例上創(chuàng)建一個(gè)控制好的競態(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)建了一個(gè)單例并初始化一個(gè)叫做?photosArray?的?NSMutableArray?屬性。

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

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

    要強(qiáng)制這個(gè)(競態(tài))條件發(fā)生,替換?PhotoManager.m?中的?sharedManager?為下面的實(shí)現(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:?類方法來強(qiáng)制發(fā)生一個(gè)上下文切換。

    打開?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)建了多個(gè)異步并發(fā)調(diào)用來實(shí)例化單例,然后引發(fā)上面描述的競態(tài)條件。

    編譯并運(yùn)行項(xiàng)目;查看控制臺輸出,你會看到多個(gè)單例被實(shí)例化,如下所示:

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

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

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

    要糾正這個(gè)狀況,實(shí)例化代碼應(yīng)該只執(zhí)行一次,并阻塞其它實(shí)例在?if?條件的臨界區(qū)運(yùn)行。這剛好就是?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ùn)行你的應(yīng)用;查看控制臺輸出,你會看到有且僅有一個(gè)單例的實(shí)例——這就是你對單例的期望!:]

    現(xiàn)在你已經(jīng)明白了防止競態(tài)條件的重要性,從?AppDelegate.m?中移除?dispatch_async?語句,并用下面的實(shí)現(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ū)已有一個(gè)線程的情況下被阻塞,直到臨界區(qū)完成為止。

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

    處理讀者與寫者問題

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    繼續(xù)在?PhotoManager.m?上工作,用下面的實(shí)現(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)并返回它。
  • 最后,你需要實(shí)例化你的?concurrentPhotoQueue?屬性。修改?sharedManager?以便像下面這樣初始化隊(duì)列:

    + (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?為一個(gè)并發(fā)隊(duì)列。第一個(gè)參數(shù)是反向DNS樣式命名慣例;確保它是描述性的,將有助于調(diào)試。第二個(gè)參數(shù)指定你的隊(duì)列是串行還是并發(fā)。

    注意:當(dāng)你在網(wǎng)上搜索例子時(shí),你會經(jīng)??慈藗儌鬟f?0?或者?NULL?給?dispatch_queue_create?的第二個(gè)參數(shù)。這是一個(gè)創(chuàng)建串行隊(duì)列的過時(shí)方式;明確你的參數(shù)總是更好。

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

    A Visual Review of Queueing 隊(duì)列的虛擬回顧

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

    我在下面提供了兩個(gè) GIF動畫來幫助你鞏固對?dispatch_async?和?dispatch_sync?的理解。包含在每個(gè) GIF 中的代碼可以提供視覺輔助;仔細(xì)注意 GIF 左邊顯示代碼斷點(diǎn)的每一步,以及右邊相關(guān)隊(duì)列的狀態(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"); }

    下面是圖中幾個(gè)步驟的說明:

  • 主隊(duì)列一路按順序執(zhí)行任務(wù)——接著是一個(gè)實(shí)例化?UIViewController?的任務(wù),其中包含了?viewDidLoad?。
  • viewDidLoad?在主線程執(zhí)行。
  • 主線程目前在?viewDidLoad?內(nèi),正要到達(dá)?dispatch_sync?。
  • dispatch_sync?Block 被添加到一個(gè)全局隊(duì)列中,將在稍后執(zhí)行。進(jìn)程將在主線程掛起直到該 Block 完成。同時(shí),全局隊(duì)列并發(fā)處理任務(wù);要記得 Block 在全局隊(duì)列中將按照 FIFO 順序出列,但可以并發(fā)執(zhí)行。
  • 全局隊(duì)列處理?dispatch_sync?Block 加入之前已經(jīng)出現(xiàn)在隊(duì)列中的任務(wù)。
  • 終于,輪到?dispatch_sync?Block 。
  • 這個(gè) Block 完成,因此主線程上的任務(wù)可以恢復(fù)。
  • viewDidLoad?方法完成,主隊(duì)列繼續(xù)處理其他任務(wù)。
  • dispatch_sync?添加任務(wù)到一個(gè)隊(duì)列并等待直到任務(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"); }

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

    下一步怎么走?

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

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

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

    同時(shí)請確保在真實(shí)設(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)為這篇翻譯不錯(cuò),也有閑錢,那你可以用支付寶隨便捐助一點(diǎn),以慰勞譯者的辛苦:

    總結(jié)

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

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

    日韩高清精品免费观看 | 国产一区二区三区免费在线观看 | 在线免费观看av网站 | 欧美色图88| 99精品视频在线观看免费 | 天天操天天操天天操天天操天天操 | 欧美日韩一区二区在线观看 | 丁香婷婷深情五月亚洲 | 免费久久网 | 国产精品高潮呻吟久久久久 | 在线免费观看一区二区三区 | 精品中文字幕视频 | 国产精品18久久久久vr手机版特色 | 色多视频在线观看 | 视频国产一区二区三区 | 国产aaa免费视频 | 久久久高清免费视频 | 国产99久久久国产精品免费二区 | 亚洲精品网站 | 国产在线精 | 在线视频1卡二卡三卡 | 欧美日韩免费一区二区三区 | 波多野结衣在线观看一区二区三区 | 91视频麻豆 | 51精品国自产在线 | 国产在线欧美在线 | 欧美极品一区二区三区 | 日韩成人欧美 | 国产精品久久久久久久久久久久 | www.精选视频.com | 亚洲一区二区精品3399 | 久久久久久久久久久久影院 | 五月婷婷中文字幕 | 亚洲免费精彩视频 | 天天干夜夜干 | 久久午夜精品视频 | 91精品推荐| 日韩欧美视频在线播放 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 日日摸日日爽 | av软件在线观看 | 日韩一区二区三区免费电影 | 国产精品欧美久久久久久 | 久久视频精品在线观看 | 中文字幕第一页在线 | 91在线小视频 | 国产精品毛片一区二区 | 美女黄色网在线播放 | 国产精品视频永久免费播放 | 99精品久久精品一区二区 | 91.精品高清在线观看 | 91天天操 | 亚洲综合精品视频 | 久久国产高清 | 91亚洲影院 | 国产区欧美 | 国产一级二级三级视频 | 天天综合导航 | 综合色在线| 中文字幕在线视频第一页 | 中文字幕在线看 | 久草视频视频在线播放 | 69性欧美| 91av片| 永久中文字幕 | 日韩av在线高清 | 国产精品剧情 | 天天干,天天插 | 亚洲欧美视频在线观看 | 91av在线免费看 | 婷婷av色综合 | 成人网中文字幕 | 日韩va欧美va亚洲va久久 | 视频在线观看亚洲 | 伊人导航 | 亚洲欧美日韩精品久久奇米一区 | av黄免费看 | 日韩一区正在播放 | 久久久久久久久久久久国产精品 | 在线观看 亚洲 | 81精品国产乱码久久久久久 | 少妇啪啪av入口 | 免费高清在线视频一区· | 91在线最新| 日本精品久久久一区二区三区 | av在线进入 | 在线小视频 | 中文字幕第一页av | 91九色蝌蚪视频 | 香蕉在线观看视频 | 日韩国产精品久久久久久亚洲 | a级片久久| 天天天天天操 | 深夜免费福利网站 | 在线观看免费一级片 | 中文字幕在线播放一区二区 | 中文字幕乱在线伦视频中文字幕乱码在线 | 国产综合精品久久 | www色网站| 欧美一级日韩三级 | 中文字幕中文字幕在线一区 | 亚洲精品高清在线观看 | 欧美日韩一区二区三区视频 | 97成人免费| 久久精品99国产国产精 | 99久久精品视频免费 | 中文字幕av在线不卡 | 亚洲高清在线精品 | 911久久香蕉国产线看观看 | 国产一级特黄毛片在线毛片 | 综合色在线| av片子在线观看 | 九九九电影免费看 | 欧美精品久久久久 | 免费中午字幕无吗 | 国产黄大片在线观看 | 国产中文字幕在线播放 | 国产一区精品在线 | 免费精品视频在线 | av色一区 | 成人午夜影视 | 天天干国产| 天天射天天做 | 美女网站色免费 | 一区二区精品国产 | 国产一级在线视频 | 日韩精品电影在线播放 | 国产高清久久 | 伊人久久国产精品 | 黄色av电影一级片 | 在线视频手机国产 | 国产一级性生活 | 亚洲午夜精 | 中文字幕在线看视频 | 亚洲国产精品久久久 | 欧美激情另类文学 | 91精品视频免费观看 | 午夜视频在线观看网站 | 日韩欧美一区二区在线 | 91精品啪在线观看国产线免费 | 婷婷激情五月 | 免费看亚洲毛片 | 日韩精品一区二 | 色先锋资源网 | 高清久久久 | 狠狠狠狠狠狠天天爱 | 国产高清免费视频 | 在线观看亚洲精品视频 | 一区二区三区在线看 | 国产高清视频色在线www | 国产视频在线免费 | 免费av网站在线 | 日韩av在线一区二区 | 国内精品久久久久久久97牛牛 | 亚洲在线成人精品 | 黄色大全免费网站 | 日韩黄色大片在线观看 | 国产 视频 久久 | 九九热只有这里有精品 | 国产精品久久久久久久久久直播 | 亚州精品在线视频 | 国产一级电影免费观看 | 欧美在线一级片 | 91精品视频一区二区三区 | 欧美成年人在线视频 | 波多野结衣电影一区二区 | 国产在线97| 国产精品第7页 | 国产精品毛片一区二区在线看 | 丁香九月激情 | 狠狠色丁香婷婷 | 伊人色播| 黄色成人在线 | 日韩欧美在线视频一区二区 | 国产精品久久久久久久毛片 | 91精品国产福利在线观看 | 最近日本韩国中文字幕 | 婷婷av色综合 | 国产成人精品一二三区 | 久久免费一级片 | 91精品视频免费看 | 久久看片网 | 国产一级片一区二区三区 | 欧美精品久久久久久久 | 91精品国产成人www | 久久成熟 | 色偷偷88欧美精品久久久 | 国内精品久久天天躁人人爽 | 精品一区二区av | 婷婷国产视频 | 国产精品久久久久久久妇 | 久久久久久97三级 | 中文 一区二区 | free. 性欧美.com| 久久久久影视 | 色偷偷网站视频 | 超碰在线94| 欧美一级看片 | 国产色在线观看 | 黄色成人91 | 久久综合九色综合久99 | 不卡视频在线 | 久久经典国产视频 | 欧美成人性战久久 | 久久草网 | 色婷婷亚洲 | 亚洲电影图片小说 | 一本色道久久精品 | 日韩有色 | 久久 在线| 欧美人人爱 | 亚洲成人欧美 | 亚州精品天堂中文字幕 | www.天天成人国产电影 | 在线亚洲欧美视频 | 中国一 片免费观看 | 91亚洲国产成人久久精品网站 | 亚洲成人av在线 | 8x成人在线 | 亚洲资源视频 | 国产一区在线不卡 | 国产精品一区二区免费 | a级国产片 | 激情网站网址 | 夜夜躁狠狠躁日日躁视频黑人 | 免费观看特级毛片 | 免费亚洲视频在线观看 | 国产高清在线一区 | 玖玖在线视频观看 | 国产一级二级三级在线观看 | 狠狠激情中文字幕 | 九九综合在线 | 久久资源总站 | av高清在线观看 | 超碰免费久久 | 一本一本久久a久久精品综合小说 | 国产精品18久久久久久首页狼 | 精品91| 中文在线资源 | 久久久久久久久久久久久国产精品 | 国产最新在线视频 | 一本一本久久a久久精品综合 | 99国产精品久久久久老师 | 亚洲狠狠婷婷综合久久久 | 久久久久亚洲国产 | 五月天亚洲综合 | 久久久久久久久毛片精品 | 日韩久久精品一区二区三区 | 国产免费亚洲 | www.黄色在线| 亚洲在线激情 | 激情久久影院 | 国产精品18久久久久久首页狼 | 天堂av在线免费观看 | 狠狠狠色丁香婷婷综合久久88 | 中文字幕日韩无 | 91在线视频网址 | 射久久 | 国内精品视频在线 | 欧美日韩国产二区 | 国产人免费人成免费视频 | 91av视频免费观看 | 国产999视频在线观看 | 欧美一区成人 | 国内小视频在线观看 | 欧美激情精品久久 | 国产精品美女久久久久久免费 | 国产在线不卡 | 亚洲欧美成人 | 四虎5151久久欧美毛片 | 国产黄色精品 | 有没有在线观看av | 国产亚洲精品久久网站 | 黄色小说网站在线 | 五月花激情| 99久久999久久久精玫瑰 | 中文字幕av专区 | 九九亚洲视频 | 亚洲电影网站 | 久久精品999| 精品国产午夜 | 亚洲国产精品视频在线观看 | 91大神在线观看视频 | 国产操在线 | 成人在线小视频 | 少妇18xxxx性xxxx片 | 激情在线网站 | 97超碰色 | 久久99国产精品 | 日本中文字幕网 | 久久这里只有精品视频首页 | 日韩国产欧美在线视频 | 国产一区在线不卡 | 国产视频资源 | 视频一区在线免费观看 | 日本3级在线观看 | 国产99在线| 亚洲精品在线播放视频 | 狠狠色狠狠色综合日日92 | 亚洲婷久久 | 国产精品18p | 国产精品久久久久久久久久东京 | 超碰97中文| 欧美在线观看视频一区二区 | 欧美日韩午夜爽爽 | 在线观看中文av | 久久久久国产免费免费 | 激情影音先锋 | 天天摸天天干天天操天天射 | 五月婷婷伊人网 | 免费av一级电影 | 日韩三级久久 | 中文字幕视频一区二区 | 久久午夜羞羞影院 | 国产网红在线观看 | 久久9视频 | 日韩欧美在线一区 | av手机在线播放 | 91热在线 | 国产精品久久久久久一二三四五 | 国产精品久久久久久久久久久久午夜片 | 久久草在线免费 | 69久久久久久久 | 青青河边草免费视频 | 国产精品原创视频 | 精品一二三四在线 | 天天爽天天摸 | 在线视频第一页 | 亚洲国产精品99久久久久久久久 | 337p日本欧洲亚洲大胆裸体艺术 | 91高清免费看 | 日韩最新中文字幕 | 在线观看视频免费播放 | 亚洲精品视频偷拍 | 国产成人av网址 | 日韩精品一区二区不卡 | 亚洲欧洲成人精品av97 | 国产精品色婷婷 | 成年人黄色免费视频 | 国产日韩欧美精品在线观看 | 91精品爽啪蜜夜国产在线播放 | 日本mv大片欧洲mv大片 | 麻豆高清免费国产一区 | 久草视频观看 | 久久久久国产精品午夜一区 | 国产精品久久久久久久久久久免费看 | 国产精品av免费在线观看 | 国产成免费视频 | 国产精品亚州 | 久久久久久片 | 国内免费久久久久久久久久久 | 色噜噜在线观看视频 | 一区二三国产 | 亚洲手机av | 日韩av一区在线观看 | 成人av高清| 激情网站五月天 | 草久久av | 成人wwwxxx视频 | 亚洲欧洲成人精品av97 | 中文av在线免费观看 | 婷婷开心久久网 | 91视频在线免费下载 | 国产一区二区在线观看免费 | 麻豆成人小视频 | 精品亚洲二区 | 一区二区三区免费在线播放 | 国产精品岛国久久久久久久久红粉 | 精品一区二区免费在线观看 | 在线观看国产麻豆 | 99在线观看精品 | 国产免费片| 中文区中文字幕免费看 | 国产视频一二区 | 国产精品一区二区av日韩在线 | 国模视频一区二区 | 狠狠干免费 | www.色综合.com | 国产成人一区三区 | 天堂av最新网址 | 999国内精品永久免费视频 | 99视频在线 | 伊人五月综合 | 色婷五月天 | 成人在线网站观看 | 美女一二三区 | 97人人视频 | 一区av在线播放 | 五月视频| 国产乱视频 | av中文字幕av | 婷婷丁香色综合狠狠色 | 久久不卡免费视频 | 欧美亚洲国产精品久久高清浪潮 | 五月丁香 | 国产不卡av在线 | 久久免费视频网站 | 麻豆视频成人 | 久久精精品视频 | 69av网| 色美女在线 | 久久久久久中文字幕 | 99 视频 高清 | 一区二区视 | 91麻豆精品 | 中文字幕免费国产精品 | 久久免费黄色网址 | 亚洲精品久久久久58 | 亚洲乱码精品久久久 | 天天操天天射天天爱 | 麻豆国产精品永久免费视频 | 99在线精品视频观看 | 高清有码中文字幕 | 人人爱人人射 | 久青草国产在线 | 国产在线一区观看 | 午夜精品99久久免费 | 日本中文字幕在线一区 | 成人在线一区二区 | 久久综合色婷婷 | 中文字幕免费不卡视频 | 天天干夜夜操视频 | 99热精品在线| 不卡av电影在线观看 | 国内偷拍精品视频 | 久久婷婷国产色一区二区三区 | 亚洲综合丁香 | 色综合婷婷久久 | 免费精品国产 | 国产乱码精品一区二区蜜臀 | 天天干夜夜操视频 | 天天色天天色 | 国产无吗一区二区三区在线欢 | 成人国产精品一区 | 亚洲少妇自拍 | 国产高清无av久久 | 9999激情| 九九热精品视频在线观看 | 久久成人亚洲欧美电影 | 国产精品一区二区免费在线观看 | av黄色一级片 | 久久久久久综合网天天 | 中文在线8新资源库 | 亚州精品在线视频 | 欧美日韩亚洲第一 | 免费国产在线观看 | 亚洲成人资源网 | 国产原创在线 | 久久精品视频在线看 | 国产免费激情久久 | 日韩中文字幕a | 国产资源在线视频 | 亚洲精品黄色 | 欧美影片| 日本精品一区二区三区在线播放视频 | 激情婷婷在线观看 | 一色屋精品视频在线观看 | 岛国精品一区二区 | 国产破处在线视频 | 日韩一区视频在线 | 99热精品在线观看 | 69欧美视频 | 韩国av免费观看 | 成人一区二区三区在线观看 | av大全在线播放 | h网站免费在线观看 | 国产一区二区三精品久久久无广告 | 国产资源av | 在线免费观看一区二区三区 | 国产色啪| zzijzzij日本成熟少妇 | 久久久久国产精品免费免费搜索 | 精品亚洲欧美无人区乱码 | 免费高清在线一区 | 91精品啪在线观看国产 | 综合精品在线 | 日本护士三级少妇三级999 | 九九视频免费观看视频精品 | 日韩精品在线播放 | 久久久久久久久久久久久国产精品 | 99久久婷婷国产综合精品 | 亚洲免费激情 | a级黄色片视频 | 欧美日韩视频免费 | 日本精品久久久久中文字幕5 | 国产黄色片在线免费观看 | 夜夜婷婷 | 自拍超碰在线 | 国产精品国产亚洲精品看不卡 | 国产精品久久久久久久毛片 | 在线视频久久 | 黄色免费观看网址 | 亚洲资源在线网 | 99久久精品免费看国产 | 97视频在线看 | 欧美精品一区二区免费 | 久久性生活片 | 日韩免费看视频 | 国产精品精品久久久久久 | 人人涩 | 91av资源在线 | 色狠狠狠 | 麻豆精品在线 | 国产精品电影一区二区 | 美女黄色网在线播放 | 天天爱av导航| 国产精品av免费在线观看 | 日韩美在线观看 | 久久久影院一区二区三区 | 狠狠躁日日躁 | 亚洲天天干 | 亚洲国产激情 | 国产福利不卡视频 | 亚洲成人xxx | 超碰在线成人 | 亚洲成人精品久久 | 蜜臀av一区二区 | 免费视频二区 | 五月激情在线 | 国产福利小视频在线 | 欧美天堂视频在线 | 99国产精品久久久久老师 | 丝袜美女在线观看 | 久久伊人国产精品 | 香蕉在线观看视频 | 成人a免费 | 久久综合久久综合久久综合 | 999男人的天堂 | 国产在线日本 | 成人av中文字幕在线观看 | 免费看污污视频的网站 | 国产综合在线视频 | 91手机在线看片 | 视色网站 | 婷婷在线播放 | 久草免费在线 | 99中文字幕视频 | 国产在线观看国语版免费 | 国产精品美女999 | 国产视频资源在线观看 | 中文字幕资源在线 | 黄色福利 | 91久久国产自产拍夜夜嗨 | 激情五月在线 | 久久草草热国产精品直播 | 91网在线观看 | 久久久三级视频 | 五月激情丁香 | 最近中文字幕高清字幕在线视频 | 国产精品 中文字幕 亚洲 欧美 | 婷婷六月综合亚洲 | 成 人 黄 色 视频 免费观看 | 国产999视频 | 国产综合精品久久 | 精品专区 | 中文字幕在线观看视频一区 | 免费高清av在线看 | 日韩av手机在线看 | 久久久精品国产一区二区 | 日韩精品一区二区免费视频 | 色香天天 | 国产精品入口a级 | 久久久国产精品久久久 | 五月婷婷丁香 | 亚洲特级片 | 欧美日韩国产二区三区 | 欧美精品免费一区二区 | 午夜视频在线瓜伦 | 午夜精品久久久久久久99 | 亚洲h视频在线 | 国产一区二区久久久久 | 国产黄色精品在线 | 国产精品都在这里 | 欧美电影在线观看 | 国产99视频在线观看 | 91精品视频免费看 | 国产在线精 | 九九热在线观看视频 | 日韩动态视频 | 又色又爽又黄 | 日韩精品不卡 | 成人av片在线观看 | 日日插日日干 | 国产精品网红直播 | 天天做日日做天天爽视频免费 | av3级在线 | 国产精品黄色影片导航在线观看 | 日日夜夜狠狠干 | 亚洲伊人网在线观看 | 国产精品一区二区在线观看 | 激情丁香5月 | 丁香婷婷基地 | 国产亚洲精品成人av久久ww | 青草视频在线 | 夜夜澡人模人人添人人看 | 亚洲aⅴ在线 | 开心激情综合网 | 国产福利91精品张津瑜 | 国产精品热视频 | 在线观看av国产 | 青草草在线 | 亚洲精品美女在线观看播放 | 日日夜夜精品网站 | 麻豆国产精品va在线观看不卡 | 亚洲精品美女久久久久网站 | 91精品资源 | 午夜在线免费观看 | 啪啪免费试看 | 在线日韩中文 | 亚洲国产精品久久久 | 91在线视频免费91 | 99精品毛片| 色婷婷久久 | 久久久精品 一区二区三区 国产99视频在线观看 | 欧美色图狠狠干 | 欧美一级性生活 | 欧美成人黄 | 五月激情婷婷丁香 | 久久黄色网页 | .国产精品成人自产拍在线观看6 | 久久久久亚洲国产精品 | 婷婷中文字幕综合 | 成人91在线观看 | 九九免费视频 | 国产一二三四在线观看视频 | 91麻豆网站 | 在线网址你懂得 | 久久久精品国产一区二区 | 国产中文字幕在线 | 精品中文字幕在线观看 | 国产精品久久99精品毛片三a | 国产丝袜制服在线 | 日本免费一二三区 | 欧美日韩免费看 | 成人a在线观看高清电影 | 国产亚洲视频系列 | 精品国产理论 | 久久午夜鲁丝片 | 久久污视频 | 免费在线观看亚洲视频 | 五月天视频网站 | 国产精品久久久999 国产91九色视频 | 十八岁以下禁止观看的1000个网站 | 在线观看中文字幕dvd播放 | 欧美成人影音 | 国内精品视频在线 | 综合久久精品 | 日韩黄色在线电影 | 国产精品久久久久久av | 五月在线视频 | 在线观看日韩免费视频 | 国产精品免费在线 | 欧美在线视频一区二区 | 在线亚洲激情 | 日韩在线观看你懂得 | 国产无套精品久久久久久 | 欧美日韩一区二区在线观看 | 久久er99热精品一区二区三区 | 日韩视频免费播放 | 这里只有精品视频在线观看 | 国产福利中文字幕 | 91人人澡| 久久99精品波多结衣一区 | 午夜123 | 亚洲91视频 | 日本一区二区高清不卡 | 在线观看日本高清mv视频 | 国产成人免费精品 | 久久久精品免费看 | 国产视频不卡一区 | 成人永久视频 | 久操97| 国产成人高清在线 | 免费在线观看成人av | 91精品成人 | 丝袜+亚洲+另类+欧美+变态 | 婷婷日 | 亚洲免费不卡 | 久草网在线 | 亚洲精品乱码久久久一二三 | 中文字幕在线视频第一页 | 五月激情丁香图片 | 日韩二区精品 | 久久久久电影网站 | 香蕉视频在线网站 | 精品黄色在线观看 | 欧美伦理电影一区二区 | 亚洲www天堂com | 中文字幕乱码在线播放 | 国产麻豆精品传媒av国产下载 | 人人看人人做人人澡 | 国产精品久久久一区二区 | 亚洲1区在线 | 在线中文字幕一区二区 | 色婷久久 | 亚洲精品国产精品乱码在线观看 | 久久久综合香蕉尹人综合网 | 欧美日一级片 | 久久99国产综合精品免费 | 国产一在线精品一区在线观看 | 久青草视频在线观看 | 亚洲精品综合欧美二区变态 | 天天人人 | 国产精品爽爽久久久久久蜜臀 | 久草免费在线视频观看 | 成年人黄色大片在线 | 免费日韩 | 日本公妇色中文字幕 | 91麻豆精品国产91久久久无限制版 | 精品国产不卡 | 天天操天天干天天摸 | 中文字幕一区二区三区四区视频 | 超碰精品在线 | 日韩欧美一区二区三区黑寡妇 | 一本一道久久a久久综合蜜桃 | av成人动漫在线观看 | 国产 亚洲 欧美 在线 | 超碰97成人 | 丁香花在线视频观看免费 | 国内精品小视频 | 九九热久久久 | 香蕉在线视频观看 | 亚洲精品av在线 | 亚洲黄色区 | 久久综合狠狠综合 | 免费国产在线精品 | 亚洲天堂网在线观看视频 | 久久不卡免费视频 | 99久久精品午夜一区二区小说 | 欧美日韩亚洲在线观看 | 国产无套一区二区三区久久 | 国产乱码精品一区二区蜜臀 | av综合 日韩 | 欧美在线视频一区二区 | 日韩一区精品 | 欧美日韩国产免费视频 | 天天操天天舔天天爽 | 国产综合精品久久 | 久久婷婷一区二区三区 | 婷婷激情欧美 | 亚洲精品视频网 | 99久热在线精品视频成人一区 | 91精品一区二区三区蜜臀 | 久久爱综合 | 国产在线观看91 | 一区二区三区在线看 | 成人av在线看 | 97成人资源站| www.成人久久 | 亚洲精品国产精品国自产 | 色婷婷av国产精品 | 国产精品久久久久久久久久不蜜月 | 久精品视频在线 | 中文字幕网站视频在线 | 欧美在线视频不卡 | 天天操天天摸天天爽 | 国产高清视频免费在线观看 | 欧美日韩激情视频8区 | 欧美日韩国产精品一区二区三区 | 又色又爽的网站 | 丁香九月婷婷综合 | 久久精品aaa | 久久99久久99精品 | 日韩在线观看电影 | 玖玖综合网 | 97成人精品视频在线观看 | 国产国产人免费人成免费视频 | 五月导航 | 天天爽夜夜爽人人爽一区二区 | 国产精品免费av | 天天干天天操天天干 | 狠狠操夜夜 | 91大神电影 | 天天操夜夜做 | 狠狠地日| 国产美女精品视频免费观看 | 在线观看日韩中文字幕 | 国产福利一区在线观看 | 国产va精品免费观看 | 91片黄在线观 | 国产一级视频在线观看 | 日韩在线观看精品 | 在线一级片 | 亚洲国产精久久久久久久 | 国产精品免费在线视频 | 亚洲精品在线观 | 欧美日韩性生活 | 玖玖在线视频观看 | 久久久99久久 | 黄色福利视频网站 | 欧美精彩视频 | 久草在线资源观看 | 久久久精品影视 | 久久国色夜色精品国产 | 国产97碰免费视频 | 四虎国产永久在线精品 | 丁香免费视频 | 香蕉久久久久久av成人 | 成人一级影视 | 91视频麻豆| 国产一区高清在线观看 | 国内精品久久久久久久久久清纯 | 18网站在线观看 | 在线高清av| 超碰在线观看av.com | 黄色网址中文字幕 | 日韩美女高潮 | 国产精品手机在线 | 中文字幕 在线看 | 欧美十八| 91传媒在线播放 | 日韩精品视频在线观看免费 | 国内精品久久影院 | 日日干天天爽 | 午夜精品剧场 | 日韩免 | 一级α片 | 国产精品电影一区二区 | 97精品国产一二三产区 | 亚洲精品国产第一综合99久久 | 91视频久久 | 亚洲精品国产综合久久 | 日本精品中文字幕在线观看 | 91精品久久久久久久91蜜桃 | 国产午夜三级一区二区三桃花影视 | 五月天婷亚洲天综合网精品偷 | 国产精品免费在线播放 | 亚洲激情av | 国产精品高清在线观看 | 黄色视屏av | 国内精品久久久久影院日本资源 | 欧美日韩亚洲在线观看 | 国产精品福利午夜在线观看 | 中文免费在线观看 | 亚洲黄色在线观看 | 91探花系列在线播放 | 国产精品自产拍在线观看网站 | 啪啪凸凸 | 一区二区中文字幕在线观看 | japanesexxxxfreehd乱熟| 久久网站最新地址 | 欧美日韩亚洲一 | 深夜免费网站 | 欧美日产在线观看 | 2000xxx影视| 日韩二区在线播放 | 在线视频你懂 | 欧美一级日韩免费不卡 | 激情婷婷丁香 | 日韩三级视频在线看 | 亚洲精品视频免费在线 | 美女av免费看 | 久久精品亚洲 | 久久a级片 | 亚洲影院天堂 | 男女拍拍免费视频 | 97超碰国产精品 | 麻豆91在线播放 | 免费成人在线观看视频 | 精品国产一区二区三区久久久蜜臀 | 精品视频一区在线观看 | 亚洲精品观看 | 精品国产精品久久一区免费式 | 91中文字幕网 | 91激情视频在线播放 | 91精品啪在线观看国产 | 91av在| 久久污视频 | 97视频播放 | 国产福利在线 | wwxxxx日本| 日韩久久精品一区二区三区下载 | 日韩电影在线观看一区二区 | 亚洲 欧美变态 另类 综合 | 久久精品国产免费看久久精品 | 久久国产精品免费观看 | 99精品视频在线 | 超碰在线成人 | 91在线porny国产在线看 | 去干成人网 | 久亚洲 | 日韩在线电影一区 | 色丁香色婷婷 | 久热免费 | 免费观看国产视频 | 国产成人精品一区二区三区福利 | 在线视频欧美日韩 | 久久精品人人做人人综合老师 | 一级国产视频 | 亚洲精品乱码久久久久v最新版 | 国产不卡一| 国产精品手机在线播放 | 国产无套一区二区三区久久 | 在线视频 日韩 | 国产二区视频在线 | 日本精品中文字幕 | 免费观看一级 | 国产一级电影网 | 四虎在线观看网址 | 精品视频免费播放 | 97超碰在线久草超碰在线观看 | 97电影院网 | 免费看污污视频的网站 | 久久久免费看片 | 亚洲精品www久久久久久 | 一区二区三区四区在线免费观看 | 国产综合在线视频 | 色婷婷久久久综合中文字幕 | 九九亚洲精品 | 精品a视频 | 亚洲成a人片在线观看中文 中文字幕在线视频第一页 狠狠色丁香婷婷综合 | 国产一区欧美日韩 | 操操爽| 午夜a区 | 中文字幕日韩高清 | 亚洲精品视频播放 | 国产福利91精品张津瑜 | 久色小说 | 91精品日韩 | 婷婷综合成人 | 中文字幕一区2区3区 | 色多多污污 | 午夜av日韩| 在线观看国产高清视频 | 亚洲一区二区三区四区精品 | 色婷婷综合久久久久中文字幕1 | 91视频久久 | 国产成人亚洲精品自产在线 | 狠狠色丁婷婷日日 | 久久久久久久久久久久久国产精品 | 亚洲热久久 | 色综合婷婷久久 | 国产91九色蝌蚪 | 日韩中文字幕在线观看 | 色在线视频网 | 亚洲精品久久久久58 | 色国产视频 | 伊人亚洲综合 | 97电影在线看视频 | 欧美成人按摩 | 在线看黄网站 | 婷婷久久五月天 | 日韩av中文字幕在线免费观看 | 国产精品一区二区av | 国产一区二区播放 | 日韩免费福利 | 国内成人综合 | 国产 一区二区三区 在线 | 欧美男同视频网站 | 国产免费久久av | 久久撸在线视频 | 视频三区 | 一区二区三区免费在线 | 精品自拍网| 久久99久久99精品中文字幕 | 日韩免费观看av | 九九久久国产精品 | 欧美午夜精品久久久久 | 免费日韩 精品中文字幕视频在线 | 日b视频在线观看网址 | 国产精品视频区 | 亚洲作爱视频 | 成人黄色大片在线免费观看 | 亚洲精品网站在线 | 欧美精品乱码久久久久久 | 午夜精品一区二区三区免费 | 日韩激情一二三区 | 麻豆小视频在线观看 | 日韩av免费在线看 | 亚洲国产精品va在线看黑人 | 激情一区二区三区欧美 | 免费高清在线观看成人 | 亚洲精品乱码久久久久久蜜桃不爽 | 81精品国产乱码久久久久久 | 亚洲视频综合在线 | 国产丝袜一区二区三区 | 99视频免费播放 | 狠狠做深爱婷婷综合一区 | 国产高清视频免费最新在线 | 亚洲三级在线 | 久久成人精品视频 | 日韩偷拍精品 | 激情欧美xxxx | 在线v | 五月天激情婷婷 | 亚洲国产成人精品电影在线观看 | 中文字幕电影网 | 婷婷中文字幕 | 久久国产精品久久精品国产演员表 | 久久蜜臀av | 亚洲国产精品成人av | 亚洲黄色片在线 | 黄网站色欧美视频 | 在线看黄色的网站 | 日韩网站一区二区 | 亚洲一二区精品 | 日韩av看片 | 欧美a视频在线观看 |