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

一句Task.Result就死鎖,這代碼還怎么寫?

開發 前端
大概就是說在 Winform 的主線程下執行 Task.Result 會造成死鎖,我也看了圖中的參考鏈接, Stephen 是絕對的大佬,不過這篇文章對死鎖的成因主要還是大段的文字灌輸,沒有真的讓你眼見為實,那這篇我就從 windbg 的角度來給它剖析下。

 [[398889]]

本文轉載自微信公眾號「一線碼農聊技術」,作者一線碼農聊技術。轉載本文請聯系一線碼農聊技術公眾號。

一、背景

1. 講故事

前些天把 .NET 高級調試 方面的文章索引到 https://github.com/ctripxchuang/dotnetfly 的過程中,發現了一個有意思的評論,截圖如下:

大概就是說在 Winform 的主線程下執行 Task.Result 會造成死鎖,我也看了圖中的參考鏈接, Stephen 是絕對的大佬,不過這篇文章對死鎖的成因主要還是大段的文字灌輸,沒有真的讓你眼見為實,那這篇我就從 windbg 的角度來給它剖析下。

二、windbg 分析

1. 真的會死鎖嗎?

看文章看截圖貌似真的會死鎖,當然我多年不玩 winform 了,也搞不清楚到底會不會,至少在 Console 中是不會的,得,先上一段測試代碼。

  1. public partial class Form1 : Form 
  2.     { 
  3.         public Form1() 
  4.         { 
  5.             InitializeComponent(); 
  6.         } 
  7.  
  8.         private void button1_Click(object sender, EventArgs e) 
  9.         { 
  10.             var jsonTask = GetJsonAsync("http://cnblogs.com").Result; 
  11.             textBox1.Text = jsonTask; 
  12.         } 
  13.  
  14.         public async static Task<string> GetJsonAsync(string uri) 
  15.         { 
  16.             using (var client = new HttpClient()) 
  17.             { 
  18.                 var jsonString = await client.GetStringAsync(uri); 
  19.  
  20.                 return jsonString; 
  21.             } 
  22.         } 
  23.     } 

代碼非常簡單,把程序跑起來,點一下 click,果然界面卡住了,有點不可思議。

2. 尋找死鎖原因

接下來趕緊祭出 windbg 附加到進程上一探究竟吧。

1) 查看主線程

界面無響應了,自然是主線程卡住了,所以急需看一下此時的主線程在干嘛?用命令 ~0s + !clrstack 即可。

  1. 0:000> !clrstack  
  2. OS Thread Id: 0x5a10 (0) 
  3.         Child SP               IP Call Site 
  4. 0000004d10dfde00 00007ffb889a10e4 [GCFrame: 0000004d10dfde00]  
  5. 0000004d10dfdf28 00007ffb889a10e4 [HelperMethodFrame_1OBJ: 0000004d10dfdf28] System.Threading.Monitor.ObjWait(Boolean, Int32, System.Object) 
  6. 0000004d10dfe040 00007ffb66920d64 System.Threading.ManualResetEventSlim.Wait(Int32, System.Threading.CancellationToken) 
  7. 0000004d10dfe0d0 00007ffb6691b4bb System.Threading.Tasks.Task.SpinThenBlockingWait(Int32, System.Threading.CancellationToken) 
  8. 0000004d10dfe140 00007ffb672601d1 System.Threading.Tasks.Task.InternalWait(Int32, System.Threading.CancellationToken) 
  9. 0000004d10dfe210 00007ffb6725cfa7 System.Threading.Tasks.Task`1[[System.__Canon, mscorlib]].GetResultCore(Boolean) 
  10. 0000004d10dfe250 00007ffb18172a1b WindowsFormsApp4.Form1.button1_Click(System.Object, System.EventArgs) [E:\net5\ConsoleApp1\WindowsFormsApp4\Form1.cs @ 26] 
  11. 0000004d10dfe2b0 00007ffb3a024747 System.Windows.Forms.Control.OnClick(System.EventArgs) 
  12. 0000004d10dfe2f0 00007ffb3a027b83 System.Windows.Forms.Button.OnClick(System.EventArgs) 
  13. 0000004d10dfe340 00007ffb3a837231 System.Windows.Forms.Button.OnMouseUp(System.Windows.Forms.MouseEventArgs) 
  14. 0000004d10dfe400 00007ffb3a7e097d System.Windows.Forms.Control.WmMouseUp(System.Windows.Forms.Message ByRef, System.Windows.Forms.MouseButtons, Int32) 
  15. 0000004d10dfe480 00007ffb3a0311cc System.Windows.Forms.Control.WndProc(System.Windows.Forms.Message ByRef) 
  16. 0000004d10dfe540 00007ffb3a0b0c97 System.Windows.Forms.ButtonBase.WndProc(System.Windows.Forms.Message ByRef) 
  17. 0000004d10dfe5c0 00007ffb3a0b0be5 System.Windows.Forms.Button.WndProc(System.Windows.Forms.Message ByRef) 
  18. 0000004d10dfe5f0 00007ffb3a030082 System.Windows.Forms.NativeWindow.Callback(IntPtr, Int32, IntPtr, IntPtr) 
  19. 0000004d10dfe690 00007ffb3a765a02 DomainBoundILStubClass.IL_STUB_ReversePInvoke(Int64, Int32, Int64, Int64) 
  20. 0000004d10dfe9d0 00007ffb776d221e [InlinedCallFrame: 0000004d10dfe9d0] System.Windows.Forms.UnsafeNativeMethods.DispatchMessageW(MSG ByRef) 
  21. 0000004d10dfe9d0 00007ffb3a0b9489 [InlinedCallFrame: 0000004d10dfe9d0] System.Windows.Forms.UnsafeNativeMethods.DispatchMessageW(MSG ByRef) 
  22. 0000004d10dfe9a0 00007ffb3a0b9489 DomainBoundILStubClass.IL_STUB_PInvoke(MSG ByRef) 
  23. 0000004d10dfea60 00007ffb3a046661 System.Windows.Forms.Application+ComponentManager.System.Windows.Forms.UnsafeNativeMethods.IMsoComponentManager.FPushMessageLoop(IntPtr, Int32, Int32) 
  24. 0000004d10dfeb50 00007ffb3a045fc7 System.Windows.Forms.Application+ThreadContext.RunMessageLoopInner(Int32, System.Windows.Forms.ApplicationContext) 
  25. 0000004d10dfebf0 00007ffb3a045dc2 System.Windows.Forms.Application+ThreadContext.RunMessageLoop(Int32, System.Windows.Forms.ApplicationContext) 
  26. 0000004d10dfec50 00007ffb181708e2 WindowsFormsApp4.Program.Main() [E:\net5\ConsoleApp1\WindowsFormsApp4\Program.cs @ 19] 
  27. 0000004d10dfee78 00007ffb776d6923 [GCFrame: 0000004d10dfee78]  

從堆棧輸出看,主線程最后是卡在 Task.Result 下的 Monitor.ObjWait 上,也就是說它還沒有取到最后的 jsonString,這就很奇怪了,都好幾分鐘了,難道網絡出問題啦 ? 我這網可是100M火力全開。。。??????

2) jsonString 哪去了?

判斷是不是網絡的問題,有一個好辦法,那就是直接暴力搜索托管堆,如果在托管堆上發現了 jsonString,那就說明是程序上的某些地方讓 Result 遲遲得不到結束,用命令 !dumpheap -type String -min 8500 + !do 000001f19002fcf0 查看即可,如下圖所示:

從圖中可以清晰的看出 html 回來了,既然都回來了,為啥還沒讓 Task.Result 結束呢?下一步就是看一看這個 html 被誰持有,使用 !gcroot 即可。

  1. 0:000> !gcroot 000001f19002fcf0 
  2. Thread 5a10: 
  3.     0000004d10dfe250 00007ffb18172a1b WindowsFormsApp4.Form1.button1_Click(System.Object, System.EventArgs) [E:\net5\ConsoleApp1\WindowsFormsApp4\Form1.cs @ 26] 
  4.         rbp+10: 0000004d10dfe2b0 
  5.             ->  000001f180007f78 WindowsFormsApp4.Form1 
  6.             ->  000001f180070d68 System.ComponentModel.EventHandlerList 
  7.             ->  000001f180071718 System.ComponentModel.EventHandlerList+ListEntry 
  8.             ->  000001f1800716d8 System.EventHandler 
  9.             ->  000001f1800716b0 System.Windows.Forms.ApplicationContext 
  10.             ->  000001f180071780 System.EventHandler 
  11.             ->  000001f18006ab38 System.Windows.Forms.Application+ThreadContext 
  12.             ->  000001f18006b140 System.Windows.Forms.Application+MarshalingControl 
  13.             ->  000001f18016c9c8 System.Collections.Queue 
  14.             ->  000001f18016ca00 System.Object[] 
  15.             ->  000001f18016c948 System.Windows.Forms.Control+ThreadMethodEntry 
  16.             ->  000001f18016c8b8 System.Object[] 
  17.             ->  000001f1800e6f80 System.Action 
  18.             ->  000001f1800e6f60 System.Runtime.CompilerServices.AsyncMethodBuilderCore+MoveNextRunner 
  19.             ->  000001f1800a77d0 WindowsFormsApp4.Form1+<GetJsonAsync>d__2 
  20.             ->  000001f1800b4e50 System.Threading.Tasks.Task`1[[System.String, mscorlib]] 
  21.             ->  000001f19002fcf0 System.String 
  22.  
  23. Found 1 unique roots (run '!GCRoot -all' to see all roots). 

從輸出結果看,這個 System.String 最后被 5a10 線程的 WindowsFormsApp4.Form1 持有,可以用 !t 驗證一下 5a10 到底是什么線程。

  1. 0:000> !t                                                                                                        Lock   
  2.        ID OSID ThreadOBJ           State GC Mode     GC Alloc Context                  Domain           Count Apt Exception 
  3.    0    1 5a10 000001f1f1b01200  2026020 Preemptive  000001F1800E70E8:000001F1800E7FD0 000001f1f1ad5b90 0     STA  
  4.    2    2 712c 000001f1f1b2a270    2b220 Preemptive  0000000000000000:0000000000000000 000001f1f1ad5b90 0     MTA (Finalizer)  

我去,5a10 竟然是主線程,真的有點混亂,主線程被卡死,string 又被主線程持有,完全是莫名其妙。

3) 尋找突破點

還是回過頭下冷靜思考下這條 引用鏈,我發現這里有一個 Queue:-> 000001f18016c9c8 System.Collections.Queue,有思路了,我可以在入 Queue 的地方下個 斷點 來調試下源代碼,工具用 DnSpy, 說干就干。

從圖中可以看到,當前入Queue時,用的是線程 10,也就是說此時 string 還沒被主線程持有,再仔細分析下這個調用棧,我想你應該就搞清楚了,反正我看完之后腦子中就有了這張圖。

從圖中可以發現,延續的 Task 最后被 WindowsFormsSynchronizationContext.Post 調度到了 Control 下的 Queue 中,而這 Queue 中的數據需要 UI線程 去執行,所以就有了下面的對話:

主線程: task小弟,你什么時候執行完呀,我在等你信號呢?

task: 老哥,我已在你家啦,你什么時候過來接我呀?

總而言之:task需要主線程來執行它,主線程卻在傻傻的等待 task 的 complete 狀態,所以延續的task永遠得不到執行,這就出現了很尷尬的場面,不知道你明白了嗎? ??????

三、破解之法

知道了前因后果,這破解之法就簡單了,大體上分兩種。

1. 禁止將 延續task 丟到 Queue 中

要切斷這條路,言外之意就是讓線程池自己結束這個 task,這樣 UI線程 就能感知到這個task已完成,最終 UI線程 就能獲取最后的 html,做法就是在 await 后加上 ConfigureAwait(false) , 參考如下:

2. 禁止阻塞主線程

如果不阻塞主線程,那么主線程就可以自由的在 Control.Queue 中獲取需要執行的任務,改法也很簡單,只需要在 GetJsonAsync 前加上 await 即可。

四、總結

結論就是多自己實操實操,理論知識是別人強制灌輸給你的,到底對還是不對,其實你自己心里也沒底,實操驗證才是真正屬于你的,而且也很難忘記,畢竟你曾今真的體驗過,實操過,驗證過。

責任編輯:武曉燕 來源: 一線碼農聊技術
相關推薦

2011-03-28 15:48:52

批量數據綁定

2011-03-24 10:24:45

批量數據綁定

2012-02-09 09:41:22

2023-11-06 08:31:58

業務代碼多線程

2019-11-15 18:00:18

MySQLSQL數據庫

2009-03-10 18:10:12

LinuxUbuntu技巧

2013-03-22 10:53:42

PyConPython

2011-06-13 09:25:01

斷號

2015-08-03 10:21:04

設計模式表達

2020-11-27 09:57:11

Python代碼PyPy

2022-08-01 10:01:11

JavaScript語言代碼庫

2021-12-17 08:55:26

Python微博機器人

2013-05-10 10:56:09

2023-09-05 23:34:52

Kubernetes云原生

2023-07-12 08:01:28

FOADMROADMOXC

2025-10-22 08:11:27

2025-03-13 11:09:47

2025-07-10 14:45:45

大模型模型GPT-4o

2016-09-12 15:26:06

戴爾

2021-06-30 00:14:24

JS代碼數組
點贊
收藏

51CTO技術棧公眾號

国产美女撒尿一区二区| 黑人乱码一区二区三区av| 欧美亚洲国产激情| 91精品一区二区三区久久久久久| 黄色网在线视频| 四虎成人免费在线| 精品一区二区三区久久| 隔壁老王国产在线精品| 欧美特级黄色录像| 免费一区二区三区在线视频| 欧美日韩亚洲一区二| 亚洲区一区二区三区| 亚洲精品人妻无码| 日本欧美在线看| 久久久久久国产精品三级玉女聊斋| 女~淫辱の触手3d动漫| 日本免费一区二区视频| 91黄色免费版| 免费看毛片的网址| lutube成人福利在线观看| 成人精品国产一区二区4080| 国产精品视频永久免费播放| 国产精品第一页在线观看| 欧美日韩在线网站| 亚洲精品suv精品一区二区| 久国产精品视频| 亚洲美女尤物影院| 亚洲国产一区二区三区青草影视 | 亚洲二区视频| 中文字幕亚洲二区| 特级西西人体4444xxxx| 亚洲日本视频在线| 欧美福利视频导航| 久久久精品麻豆| 天堂在线中文网官网| 亚洲综合一区二区| 成人在线观看www| eeuss影院在线播放| 久久日韩精品一区二区五区| 国产一区再线| 狠狠综合久久av一区二区| 久久99精品国产| 国产女人18毛片水18精品| 在线免费观看国产精品| 美女尤物久久精品| 91福利视频在线观看| 香蕉视频一区二区| 亚洲欧洲另类| 午夜精品在线视频| 日本网站在线免费观看| 国模大胆一区二区三区| 久久久久久亚洲精品不卡| 在线观看成人毛片| 在线精品视频在线观看高清| 日韩三级影视基地| 91高清免费看| 综合一区av| 欧美久久久精品| 美女毛片在线观看| 亚洲网址在线| 91精品国产高清久久久久久| 国产精品久久久免费视频| 国产精品久久777777毛茸茸| 欧美在线视频一区| 波多野结衣mp4| 青青草国产成人av片免费| 国产精品日韩在线播放| 一本一道人人妻人人妻αv| 麻豆久久久久久| 成人性生交xxxxx网站| 国产黄色片免费观看| 国产盗摄精品一区二区三区在线 | 亚洲四区在线观看| 国产美女视频免费| 牛牛精品在线| 第一福利永久视频精品| 欧美 日韩精品| 成人午夜在线| 日韩一区二区三区高清免费看看| 中国老熟女重囗味hdxx| 国产精品17p| 亚洲欧美国产精品| 91导航在线观看| 亚洲男女av一区二区| 久久久亚洲国产天美传媒修理工| 日韩欧美高清在线观看| 日韩黄色免费电影| 91中文在线观看| 亚洲 另类 春色 国产| 国产日韩精品久久久| 中文字幕在线中文字幕日亚韩一区| 91中文在线| 欧美日韩激情视频8区| 天天操天天爱天天爽| 少妇精品在线| 亚洲精品视频网上网址在线观看| 免费成人美女女在线观看| 亚洲天堂手机在线| 亚洲成人一品| 综合激情国产一区| 精品少妇久久久| 日本91福利区| 国产精品二区三区四区| 国产精品无码2021在线观看| 一区二区在线观看不卡| www.亚洲天堂网| 美国十次综合久久| 亚洲欧美一区二区三区在线| 91视频最新网址| 亚洲国产裸拍裸体视频在线观看乱了中文 | 日日欢夜夜爽一区| 成人激情av| 午夜激情视频在线| 精品国产福利在线| 人妻巨大乳一二三区| 精品产国自在拍| 91成人在线观看国产| 精品国产无码AV| 欧美国产精品专区| 国产成人在线免费看| 婷婷视频一区二区三区| 色综久久综合桃花网| 91video| 国产91精品露脸国语对白| 一区二区三区我不卡| 韩国成人漫画| 日韩精品免费观看| 国产无遮挡裸体免费视频| 狠狠色丁香婷综合久久| 日韩精彩视频| 久久毛片亚洲| 国产婷婷97碰碰久久人人蜜臀 | 亚洲qvod图片区电影| 成年人在线看| 色老汉av一区二区三区| 国产国语性生话播放| 亚洲国产91| 肥熟一91porny丨九色丨| 精品孕妇一区二区三区| 欧美色欧美亚洲另类二区| 91视频在线网站| 久久精品动漫| 日本一区二区精品| 成人教育av| 亚洲精品在线视频| 久久久免费高清视频| 99精品久久久久久| 欧美三级在线观看视频| 牛牛精品成人免费视频| 性视频1819p久久| 五月婷婷丁香花| 精品色蜜蜜精品视频在线观看| 2一3sex性hd| 99在线观看免费视频精品观看| 国产一区免费在线| 欧美大片高清| 在线观看91久久久久久| 中文字幕 视频一区| 国产精品久久久久久久久图文区 | 久久天堂影院| 色偷偷亚洲男人天堂| 岳乳丰满一区二区三区| 国产精品久久久久久久久快鸭| 手机免费av片| 欧美在线三区| 国产日韩一区二区三区| 性欧美18~19sex高清播放| 精品一区二区三区电影| 夜夜躁日日躁狠狠久久av| 国产精品少妇自拍| 午夜激情视频网| 亚洲人成人一区二区三区| 国内精品久久国产| 偷拍中文亚洲欧美动漫| 色婷婷**av毛片一区| 成人午夜免费福利| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 日韩综合av| 久久久亚洲影院你懂的| 欧美成熟毛茸茸| 欧美日韩成人在线一区| 中文字幕手机在线观看| 成人黄色网址在线观看| 久久国产乱子伦免费精品| 97精品国产一区二区三区| αv一区二区三区| 日韩精品专区| 欧美巨乳美女视频| 毛片免费在线| 日韩一级完整毛片| 五月天综合激情网| 国产精品传媒在线| 日本69式三人交| 免费在线观看日韩欧美| 国产精品入口芒果| 郴州新闻综合频道在线直播| 成人免费视频观看视频| 中文字幕系列一区| 韩日欧美一区二区| 免费高清完整在线观看| 亚洲美女免费精品视频在线观看| 97人妻精品一区二区三区动漫| 精品国产999| 成年人av电影| 国产精品视频一二三| 午夜不卡久久精品无码免费| 蜜桃久久久久久久| 久久亚洲中文字幕无码| 影视亚洲一区二区三区| 日韩欧美一区二区三区四区五区| 亚洲国产一区二区三区网站| 国产精品普通话| 深夜av在线| 久久久久国产精品免费网站| 黄色片网站在线| 国产亚洲精品高潮| 亚洲欧美日韩综合在线| 精品三级在线看| 国产精品一二三四五区| 在线观看日产精品| 你懂的国产在线| 亚洲福利视频导航| 国产十六处破外女视频| 综合欧美一区二区三区| 欧美激情亚洲色图| 久久久亚洲欧洲日产国码αv| 999精品免费视频| 国产二区国产一区在线观看| 亚洲精品在线视频播放| 蜜桃久久久久久| 日本久久久久久久久久久久| 久久av在线| 国产极品粉嫩福利姬萌白酱| 在线观看日韩av电影| 成人小视频在线观看免费| 亚洲二区三区不卡| 色中文字幕在线观看| 欧美韩国日本在线观看| 四虎一区二区| 成人在线国产| 亚洲欧美日韩在线综合| 日本欧美国产| 亚洲一区bb| 亚洲精品成人影院| 四虎精品欧美一区二区免费| 一区二区三区四区在线观看国产日韩| 亚洲午夜在线观看| 天天久久综合| 欧美另类videos| 好看的亚洲午夜视频在线| 国产一级做a爰片久久毛片男| 欧美~级网站不卡| 亚洲精品蜜桃久久久久久| 激情综合在线| 国产极品尤物在线| 羞羞视频在线观看欧美| 色婷婷综合久久久久中文字幕| 视频一区二区三区中文字幕| www欧美激情| 久久99国产精品免费| 久久精品一卡二卡| 成人黄色一级视频| 波多野结衣一本| 国产精品视频看| 黄色a级片在线观看| 一区二区久久久久| 草久视频在线观看| 欧美中文字幕亚洲一区二区va在线 | 色欲狠狠躁天天躁无码中文字幕 | 97久久精品人人做人人爽| 色噜噜在线观看| 国产精品你懂的在线| 国产大片免费看| 精品久久久久久亚洲精品| 欧美男人天堂网| 日韩精品自拍偷拍| 色视频在线观看免费| 精品国产欧美成人夜夜嗨| 国产又色又爽又黄刺激在线视频| 全亚洲最色的网站在线观看| 成人在线免费av| 国产福利一区二区三区在线观看| 欧美人体视频| 中文字幕日韩精品一区二区| 伊人久久亚洲热| 一区二区xxx| 国产成a人亚洲精品| 久久精品国产亚洲av久| 亚洲同性gay激情无套| 日韩欧美三级视频| 欧美日韩国产片| 欧美一区二区黄片| 中文字幕亚洲一区二区三区| 好看的中文字幕在线播放| 国产91色在线|免| 日韩精品一区二区三区中文| 欧美一级爽aaaaa大片| 欧美久久一级| 国产理论在线播放| 成人激情av网| 婷婷在线精品视频| 狠狠色狠狠色综合日日五| 一本色道久久综合精品婷婷| 精品一区精品二区| caopo在线| 国产精品久久999| 加勒比色老久久爱综合网| 亚洲自拍三区| 国产精品嫩草99av在线| 日韩av福利在线观看| 久久久三级国产网站| 久久久久久久久久99| 欧美日韩第一区日日骚| 性xxxxbbbb| 欧美激情三级免费| 91精品麻豆| 日韩三级在线播放| 亚洲一区二区动漫| 亚洲成人精品在线播放| 国产精品国产三级国产| 午夜精品免费观看| 亚洲成人网在线观看| a视频在线观看| 成人黄色大片在线免费观看| 精品黄色一级片| 999香蕉视频| 99re在线精品| 天天操天天射天天爽| 日韩丝袜美女视频| 成人欧美在线| 成人字幕网zmw| 清纯唯美综合亚洲| 亚洲少妇久久久| 国产午夜精品美女毛片视频| av大片在线免费观看| 亚洲国模精品一区| ****av在线网毛片| 国产福利久久精品| 亚洲狠狠婷婷| 国产精品无码在线| 亚洲国产成人高清精品| 国产77777| 国模精品系列视频| 久久综合社区| 成年人视频观看| www亚洲一区| 无码视频一区二区三区| 亚洲一区二区久久久| 视频一区在线免费看| 亚洲精品国产精品久久| 六月丁香综合在线视频| 久久精品一区二区三区四区五区| 欧美女孩性生活视频| 欧美69xxxx| 99精品在线直播| 亚洲经典三级| 国产精品无码久久久久久| 色94色欧美sute亚洲线路一久| 国产裸舞福利在线视频合集| 国产精品亚洲第一区| 香蕉av一区二区| 国产a级片视频| 性久久久久久久久久久久| 深夜视频在线免费| 国产精品久久久久久久久久尿| jizzjizz欧美69巨大| 爱爱爱爱免费视频| 亚洲精品成a人| 香蕉av在线播放| 国产精品入口免费视频一| 欧美69视频| 人妻丰满熟妇aⅴ无码| 欧美视频在线观看一区二区| 毛片av在线| 国产伦精品一区二区| 老妇喷水一区二区三区| 国产一区二区三区视频播放| 日韩欧美成人一区| 天堂电影一区| 久久久成人精品一区二区三区| 福利一区二区在线| 蜜臀尤物一区二区三区直播| 久久视频在线播放| 麻豆成人入口| 中文字幕国产免费| 亚洲mv在线观看| 91这里只有精品| 国产精品视频免费观看| 日本中文字幕一区二区有限公司| 免费在线黄色网| 国产视频亚洲视频| 日本精品在线观看| 91在线视频观看免费| 亚洲综合偷拍欧美一区色| 狠狠v欧美ⅴ日韩v亚洲v大胸 | 欧美激情一区二区三区成人| 国产欧美日韩在线一区二区| 国产又粗又猛又爽又黄| 欧美亚洲动漫精品| av老司机免费在线|