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

深入JVM鎖機制之一:synchronized

開發 后端
目前在Java中存在兩種鎖機制:synchronized和Lock,Lock接口及其實現類是JDK5增加的內容,其作者是大名鼎鼎的并發專家Doug Lea。本文并不比較synchronized與Lock孰優孰劣,只是介紹二者的實現原理。

目前在Java中存在兩種鎖機制:synchronized和Lock,Lock接口及其實現類是JDK5增加的內容,其作者是大名鼎鼎的并發專家Doug Lea。本文并不比較synchronized與Lock孰優孰劣,只是介紹二者的實現原理。

數據同步需要依賴鎖,那鎖的同步又依賴誰?synchronized給出的答案是在軟件層面依賴JVM,而Lock給出的方案是在硬件層面依賴特殊的CPU指令,大家可能會進一步追問:JVM底層又是如何實現synchronized的?

本文所指說的JVM是指Hotspot的6u23版本,下面首先介紹synchronized的實現:

synrhronized關鍵字簡潔、清晰、語義明確,因此即使有了Lock接口,使用的還是非常廣泛。其應用層的語義是可以把任何一個非null對象作為"鎖",當synchronized作用在方法上時,鎖住的便是對象實例(this);當作用在靜態方法時鎖住的便是對象對應的Class實例,因為Class數據存在于***帶,因此靜態方法鎖相當于該類的一個全局鎖;當synchronized作用于某一個對象實例時,鎖住的便是對應的代碼塊。在HotSpot JVM實現中,鎖有個專門的名字:對象監視器。

1. 線程狀態及狀態轉換

當多個線程同時請求某個對象監視器時,對象監視器會設置幾種狀態用來區分請求的線程:

◆ Contention List:所有請求鎖的線程將被首先放置到該競爭隊列。

◆ Entry List:Contention List中那些有資格成為候選人的線程被移到Entry List。

◆ Wait Set:那些調用wait方法被阻塞的線程被放置到Wait Set。

◆ OnDeck:任何時刻最多只能有一個線程正在競爭鎖,該線程稱為OnDeck。

◆ Owner:獲得鎖的線程稱為Owner。

◆ !Owner:釋放鎖的線程。

下圖反映了個狀態轉換關系:

新請求鎖的線程將首先被加入到ConetentionList中,當某個擁有鎖的線程(Owner狀態)調用unlock之后,如果發現EntryList為空則從ContentionList中移動線程到EntryList,下面說明下ContentionList和EntryList的實現方式:

1.1 ContentionList虛擬隊列

ContentionList并不是一個真正的Queue,而只是一個虛擬隊列,原因在于ContentionList是由Node及其next指針邏輯構成,并不存在一個Queue的數據結構。ContentionList是一個后進先出(LIFO)的隊列,每次新加Node時都會在隊頭進行,通過CAS改變***個節點的的指針為新增節點,同時設置新增節點的next指向后續節點,而取得操作則發生在隊尾。顯然,該結構其實是個Lock-Free的隊列。

因為只有Owner線程才能從隊尾取元素,也即線程出列操作無爭用,當然也就避免了CAS的ABA問題。

1.2 EntryList

EntryList與ContentionList邏輯上同屬等待隊列,ContentionList會被線程并發訪問,為了降低對ContentionList隊尾的爭用,而建立EntryList。Owner線程在unlock時會從ContentionList中遷移線程到EntryList,并會指定EntryList中的某個線程(一般為Head)為Ready(OnDeck)線程。Owner線程并不是把鎖傳遞給OnDeck線程,只是把競爭鎖的權利交給OnDeck,OnDeck線程需要重新競爭鎖。這樣做雖然犧牲了一定的公平性,但極大的提高了整體吞吐量,在Hotspot中把OnDeck的選擇行為稱之為“競爭切換”。

OnDeck線程獲得鎖后即變為owner線程,無法獲得鎖則會依然留在EntryList中,考慮到公平性,在EntryList中的位置不發生變化(依然在隊頭)。如果Owner線程被wait方法阻塞,則轉移到WaitSet隊列;如果在某個時刻被notify/notifyAll喚醒,則再次轉移到EntryList。

2. 自旋鎖

那些處于ContetionList、EntryList、WaitSet中的線程均處于阻塞狀態,阻塞操作由操作系統完成(在Linxu下通過pthread_mutex_lock函數)。線程被阻塞后便進入內核(Linux)調度狀態,這個會導致系統在用戶態與內核態之間來回切換,嚴重影響鎖的性能。

緩解上述問題的辦法便是自旋,其原理是:當發生爭用時,若Owner線程能在很短的時間內釋放鎖,則那些正在爭用線程可以稍微等一等(自旋),在Owner線程釋放鎖后,爭用線程可能會立即得到鎖,從而避免了系統阻塞。但Owner運行的時間可能會超出了臨界值,爭用線程自旋一段時間后還是無法獲得鎖,這時爭用線程則會停止自旋進入阻塞狀態(后退)。基本思路就是自旋,不成功再阻塞,盡量降低阻塞的可能性,這對那些執行時間很短的代碼塊來說有非常重要的性能提高。自旋鎖有個更貼切的名字:自旋-指數后退鎖,也即復合鎖。很顯然,自旋在多處理器上才有意義。

還有個問題是,線程自旋時做些啥?其實啥都不做,可以執行幾次for循環,可以執行幾條空的匯編指令,目的是占著CPU不放,等待獲取鎖的機會。所以說,自旋是把雙刃劍,如果旋的時間過長會影響整體性能,時間過短又達不到延遲阻塞的目的。顯然,自旋的周期選擇顯得非常重要,但這與操作系統、硬件體系、系統的負載等諸多場景相關,很難選擇,如果選擇不當,不但性能得不到提高,可能還會下降,因此大家普遍認為自旋鎖不具有擴展性。

對自旋鎖周期的選擇上,HotSpot認為***時間應是一個線程上下文切換的時間,但目前并沒有做到。經過調查,目前只是通過匯編暫停了幾個CPU周期,除了自旋周期選擇,HotSpot還進行許多其他的自旋優化策略,具體如下:

◆ 如果平均負載小于CPUs則一直自旋。

◆ 如果有超過(CPUs/2)個線程正在自旋,則后來線程直接阻塞。

◆ 如果正在自旋的線程發現Owner發生了變化則延遲自旋時間(自旋計數)或進入阻塞。

◆ 如果CPU處于節電模式則停止自旋。

◆ 自旋時間的最壞情況是CPU的存儲延遲(CPU A存儲了一個數據,到CPU B得知這個數據直接的時間差)。

◆ 自旋時會適當放棄線程優先級之間的差異。

那synchronized實現何時使用了自旋鎖?答案是在線程進入ContentionList時,也即***步操作前。線程在進入等待隊列時首先進行自旋嘗試獲得鎖,如果不成功再進入等待隊列。這對那些已經在等待隊列中的線程來說,稍微顯得不公平。還有一個不公平的地方是自旋線程可能會搶占了Ready線程的鎖。自旋鎖由每個監視對象維護,每個監視對象一個。

3. 偏向鎖

在JVM1.6中引入了偏向鎖,偏向鎖主要解決無競爭下的鎖性能問題,首先我們看下無競爭下鎖存在什么問題:
現在幾乎所有的鎖都是可重入的,也即已經獲得鎖的線程可以多次鎖住/解鎖監視對象,按照之前的HotSpot設計,每次加鎖/解鎖都會涉及到一些CAS操作(比如對等待隊列的CAS操作),CAS操作會延遲本地調用,因此偏向鎖的想法是一旦線程***次獲得了監視對象,之后讓監視對象“偏向”這個線程,之后的多次調用則可以避免CAS操作,說白了就是置個變量,如果發現為true則無需再走各種加鎖/解鎖流程。但還有很多概念需要解釋、很多引入的問題需要解決。

3.1 CAS及SMP架構

CAS為什么會引入本地延遲?這要從SMP(對稱多處理器)架構說起,下圖大概表明了SMP的結構:

其意思是所有的CPU會共享一條系統總線(BUS),靠此總線連接主存。每個核都有自己的一級緩存,各核相對于BUS對稱分布,因此這種結構稱為“對稱多處理器”。

而CAS的全稱為Compare-And-Swap,是一條CPU的原子指令,其作用是讓CPU比較后原子地更新某個位置的值,經過調查發現,其實現方式是基于硬件平臺的匯編指令,就是說CAS是靠硬件實現的,JVM只是封裝了匯編調用,那些AtomicInteger類便是使用了這些封裝后的接口。

Core1和Core2可能會同時把主存中某個位置的值Load到自己的L1 Cache中,當Core1在自己的L1 Cache中修改這個位置的值時,會通過總線,使Core2中L1 Cache對應的值“失效”,而Core2一旦發現自己L1 Cache中的值失效(稱為Cache命中缺失)則會通過總線從內存中加載該地址***的值,大家通過總線的來回通信稱為“Cache一致性流量”,因為總線被設計為固定的“通信能力”,如果Cache一致性流量過大,總線將成為瓶頸。而當Core1和Core2中的值再次一致時,稱為“Cache一致性”,從這個層面來說,鎖設計的***目標便是減少Cache一致性流量。

而CAS恰好會導致Cache一致性流量,如果有很多線程都共享同一個對象,當某個Core CAS成功時必然會引起總線風暴,這就是所謂的本地延遲,本質上偏向鎖就是為了消除CAS,降低Cache一致性流量。

Cache一致性:

上面提到Cache一致性,其實是有協議支持的,現在通用的協議是MESI(最早由Intel開始支持),具體參考:http://en.wikipedia.org/wiki/MESI_protocol,以后會仔細講解這部分。

Cache一致性流量的例外情況:

其實也不是所有的CAS都會導致總線風暴,這跟Cache一致性協議有關,具體參考:http://blogs.oracle.com/dave/entry/biased_locking_in_hotspot

NUMA(Non Uniform Memory Access Achitecture)架構:

與SMP對應還有非對稱多處理器架構,現在主要應用在一些高端處理器上,主要特點是沒有總線,沒有公用主存,每個Core有自己的內存,針對這種結構此處不做討論。

3.2 偏向解除

偏向鎖引入的一個重要問題是,在多爭用的場景下,如果另外一個線程爭用偏向對象,擁有者需要釋放偏向鎖,而釋放的過程會帶來一些性能開銷,但總體說來偏向鎖帶來的好處還是大于CAS代價的。

4. 總結

關于鎖,JVM中還引入了一些其他技術比如鎖膨脹等,這些與自旋鎖、偏向鎖相比影響不是很大,這里就不做介紹。
通過上面的介紹可以看出,synchronized的底層實現主要依靠Lock-Free的隊列,基本思路是自旋后阻塞,競爭切換后繼續競爭鎖,稍微犧牲了公平性,但獲得了高吞吐量。下面會繼續介紹JVM鎖中的Lock(深入JVM鎖2-Lock)。

原文鏈接:http://blog.csdn.net/chen77716/article/details/6618779

【編輯推薦】

  1. 深入JVM鎖機制之二:Lock
  2. JVM中可生成的***Thread數量
  3. Java虛擬機 JVM的介紹
  4. Google新結構化編程語言Dart可運行在Jvm上
  5. Eclipse推JVM語言Xtend 繼續擁抱Java

 

責任編輯:林師授 來源: chen77716的博客
相關推薦

2011-11-28 12:55:37

JavaJVM

2022-07-04 08:01:01

鎖優化Java虛擬機

2021-08-03 07:40:46

Synchronize鎖膨脹性能

2010-11-22 14:18:32

MySQL鎖機制

2023-10-13 13:30:00

MySQL鎖機制

2021-09-24 08:10:40

Java 語言 Java 基礎

2023-02-14 08:00:00

MySQL索引查詢

2024-02-26 07:36:09

lockJava語言

2023-10-31 10:51:56

MySQLMVCC并發性

2024-12-02 09:01:23

Java虛擬機內存

2024-03-06 08:00:56

javaAQS原生

2021-06-27 21:24:55

RedissonJava數據

2021-07-08 09:21:17

ZooKeeper分布式鎖 Curator

2011-08-24 09:30:29

JavaJVM

2019-10-11 08:41:35

JVM虛擬機語言

2018-10-16 16:00:39

數據庫鎖舞MySQL

2018-08-07 10:44:50

緩存技術瀏覽器

2022-03-24 13:36:18

Java悲觀鎖樂觀鎖

2017-09-20 08:07:32

java加載機制

2010-09-26 16:55:31

JVM學習筆記
點贊
收藏

51CTO技術棧公眾號

成人午夜伦理影院| 99精品在免费线中文字幕网站一区| av电影一区二区| 久久av红桃一区二区小说| 亚洲色图欧美自拍| 欧美精品hd| 国产精品一卡二卡| 久久久视频精品| 一区二区三区免费在线观看视频 | 在线国产成人影院| 国产精品国产三级国产三级人妇| 91免费看片网站| 欧美黄色免费观看| 亚洲另类av| 在线免费亚洲电影| av中文字幕av| 亚洲经典一区二区三区| 性伦欧美刺激片在线观看| 最近更新的2019中文字幕 | 欧美成a人片在线观看久| 国产精品视频九色porn| 国产在线精品一区| 亚洲视频一区在线播放| 日韩欧美高清在线播放| 欧美大胆人体bbbb| 五月婷婷之综合激情| 污污影院在线观看| 中文字幕精品一区二区精品绿巨人 | 欧美亚洲在线视频| 久久久久久国产免费a片| 国产区一区二| 欧美视频精品在线观看| 成人免费观看cn| 国产黄色在线观看| 91麻豆福利精品推荐| 国产精品入口福利| 五月婷婷开心网| 中文字幕一区二区三三| 一区二区亚洲欧洲国产日韩| 欧美日韩一区二区区| 国精产品一区一区三区四川| 五月综合激情日本mⅴ| 视频一区视频二区视频三区视频四区国产 | 男人在线观看视频| 免费看日本一区二区| 欧美一二三区在线观看| 超碰在线97免费| 国产美女高潮在线观看| 亚洲激情自拍偷拍| 五月天男人天堂| 91大神xh98hx在线播放| 免费在线观看精品| 国产99在线|中文| 日韩免费不卡视频| 欧美日韩一区二区高清| 久久九九亚洲综合| 自拍偷拍第9页| 精品日产免费二区日产免费二区| 精品国产一区二区三区四区四| 一级做a免费视频| 成人黄色免费观看| 日本久久一区二区| 国产超级av在线| 欧美aa免费在线| 亚洲精品大片www| 免费看污污视频| 国产人成在线视频| 国产欧美日韩在线视频| 欧美一区二区三区成人久久片 | 久久亚洲欧美| 日本一区二区在线免费播放| www.日本精品| 国产日韩一区二区三区在线播放 | 免费黄频在线观看| 成人激情久久| 91麻豆精品国产91久久久 | 成人99免费视频| 国产一区二区三区色淫影院| 午夜性色福利视频| 91视频免费看| 日韩欧美三级电影| 免费在线观看黄色网| 国产日韩av一区| 色涩成人影视在线播放| 人人干在线视频| 亚洲色图制服诱惑| 菠萝蜜视频在线观看入口| 免费污视频在线| 五月天激情综合| 不卡影院一区二区| 国精品产品一区| 欧美日韩在线精品一区二区三区激情 | 国产一区二区视频在线观看| 国产男女无套免费网站| 成人丝袜18视频在线观看| 精品人伦一区二区三区| 黄色美女网站在线观看| 国产欧美1区2区3区| 在线成人性视频| 密臀av在线| 欧美性猛交xxxx乱大交极品| 美女网站视频黄色| 蜜桃精品视频| 亚洲精品在线看| 免费视频91蜜桃| 自拍偷拍欧美专区| 69国产精品成人在线播放| 国产精品无码粉嫩小泬| 免费久久99精品国产| 国产欧美日韩中文字幕在线| 亚洲欧美高清视频| 国产婷婷色一区二区三区| 特级毛片在线免费观看| av色综合久久天堂av色综合在| 香蕉av福利精品导航| www亚洲成人| 黄色日韩网站| 亚洲国产私拍精品国模在线观看| 中文字幕第4页| 国产一区二区三区四区三区四 | 国产热re99久久6国产精品| 亚洲国产成人一区二区| 国产欧美久久久精品影院| 欧美黄色免费网址| 久久婷婷五月综合色丁香| 精品1区2区在线观看| 欧美自拍偷拍网| 国产视频一区欧美| 国产一区深夜福利| 日批视频在线播放| 亚洲欧美国产毛片在线| 97公开免费视频| 日韩成人综合网站| 亚洲女同精品视频| 日本熟妇毛耸耸xxxxxx| 国产在线精品一区二区夜色| 午夜一区二区三区| 国产黄大片在线观看| 91精品欧美福利在线观看 | 暴力调教一区二区三区| 一本色道久久综合亚洲二区三区| 天堂av中文在线观看| 在线不卡中文字幕| 久久久视频6r| 国产欧美一区二区色老头 | 92看片淫黄大片欧美看国产片| 青青草在线视频免费观看| 亚洲综合丁香婷婷六月香| 久久精品国产露脸对白| 成人激情电影在线| 国产999在线观看| 爽爽视频在线观看| 中文字幕日韩一区| 污污的网站18| 成人婷婷网色偷偷亚洲男人的天堂| 4438全国成人免费| 人妻夜夜爽天天爽| 亚洲一区二区三区免费视频| 欧美xxxxxbbbbb| 91欧美日韩| 国产美女被下药99| 日本三级视频在线观看| 欧美午夜不卡在线观看免费| 亚洲欧美日韩偷拍| 在线精品亚洲| 国产一区免费在线| 成人日批视频| 日韩欧美中文一区| 成年人午夜剧场| 国产精品资源在线观看| 成人午夜免费剧场| 一区二区三区在线资源| 久久久久久久久久av| 亚洲第一精品网站| 亚洲一二三区视频在线观看| 韩国一区二区三区四区| 亚洲视屏一区| 激情久久av| 春色校园综合激情亚洲| 亚洲第一福利在线观看| 天天操天天干视频| 91在线国内视频| 国产一区亚洲二区三区| 怕怕欧美视频免费大全| 国产精品国产三级国产aⅴ9色| 99re在线视频| 51精品国自产在线| 国产污视频在线看| 99国产精品国产精品毛片| 韩国日本在线视频| 欧美韩日一区| 91国产在线免费观看| 国产精品论坛| 中文字幕欧美日韩在线| 国产精品无码免费播放| 亚洲国产精品成人综合| 久久精品无码一区二区三区毛片| 亚洲高清不卡| 久久综合九色综合久99| 国产毛片精品久久| 欧美激情视频播放| 国产香蕉视频在线看| 在线免费观看成人短视频| 亚洲一级生活片| 91美女片黄在线观看| 麻豆传传媒久久久爱| 手机亚洲手机国产手机日韩| 国产精品视频一区二区三区经| 日本中文字幕在线2020| 亚洲国产精品久久91精品| 中文字幕欧美色图| 亚洲国产乱码最新视频 | 日韩视频网站在线观看| 久久影视免费观看| 青青草手机在线| 555夜色666亚洲国产免| 东京热一区二区三区四区| av午夜精品一区二区三区| jizz欧美性11| 一区二区高清| 免费观看国产视频在线| 精品欧美激情在线观看| 国产精品免费在线| 国产成人精品亚洲日本在线观看| 欧美多人乱p欧美4p久久| 欧洲伦理片一区 二区 三区| 欧美成人官网二区| 怡春院在线视频| 一区二区三区免费在线观看| 国产精品三级在线观看无码| 国产麻豆成人精品| 人妻丰满熟妇av无码区app| 自产国语精品视频| 亚洲成人第一| 日韩精品免费一区二区夜夜嗨| 91啪国产在线| 欧美网站免费| 国产精品jvid在线观看蜜臀| 成年人黄色大片在线| 欧美寡妇偷汉性猛交| 高清全集视频免费在线| 伊人久久久久久久久久久久久| 亚州男人的天堂| 亚洲高清不卡av| 俄罗斯嫩小性bbwbbw| 91精品国产综合久久福利| 亚洲图片在线播放| 欧美日韩黄视频| 一级特黄aaa大片在线观看| 红桃av永久久久| 九热这里只有精品| 亚洲综合成人网| 国产免费无码一区二区视频| 国产日韩v精品一区二区| 国产在线观看h| 久久久美女毛片| av网站免费在线看| 国产精品国产自产拍在线| 男女性高潮免费网站| 亚洲国产欧美一区二区三区丁香婷| 日产亚洲一区二区三区| 欧美日韩在线一区| 中文字幕第一页在线播放| 91精品蜜臀在线一区尤物| 亚洲第一天堂影院| 国产丝袜高跟一区| 亚洲成人三级| 欧美丰满少妇xxxxx| 九色porny丨国产首页在线| 日韩免费av在线| www 久久久| 国产在线一区二区三区播放| 久久av导航| 可以免费看的黄色网址| 99国产精品自拍| 中文字幕第88页| 成人免费视频播放| 日本欧美一区二区三区不卡视频| 亚洲免费观看高清完整版在线观看熊 | 黄色一区二区三区| 伊人免费在线观看| 亚洲第一福利网| 91大神xh98hx在线播放| 午夜精品一区二区三区在线播放 | 99国产在线| 国产亚洲电影| 国产黄色激情视频| 日韩激情中文字幕| jjzz黄色片| 国产女主播一区| 国产乡下妇女做爰视频| 欧美视频一区在线观看| 人妻少妇精品无码专区| 日韩亚洲第一页| 日韩伦理在线| 51国产成人精品午夜福中文下载| 伊人久久大香线蕉av不卡| 中国一级黄色录像| 日韩电影在线一区| 好吊色视频一区二区三区| 国产精品免费丝袜| 国产农村妇女aaaaa视频| 日韩欧美国产系列| 1区2区3区在线观看| 欧美在线视频一二三| 精品国产一级| 一区二区三区电影| 丝袜诱惑亚洲看片| 久久久久久婷婷| 亚洲黄色在线视频| 中文字幕有码视频| 亚洲欧美激情视频| а√天堂中文资源在线bt| 91老司机精品视频| 成人午夜国产| 日本不卡在线观看视频| 成人在线综合网站| 欧美精品一级片| 4438x成人网最大色成网站| 国产黄色免费在线观看| 欧美一级免费视频| 久久久亚洲欧洲日产| 男人天堂a在线| 国产成人av电影在线观看| 一级黄色片日本| 欧美久久久久久蜜桃| porn亚洲| 国产精品久久久久久久久久东京| 伊人成综合网yiren22| 久久久久久久午夜| 99久久伊人网影院| 久久久久久久久久久久久久av| 亚洲成人国产精品| 欧美女同一区| 国产不卡一区二区三区在线观看| 欧美在线高清| 又大又长粗又爽又黄少妇视频| 亚洲欧美乱综合| 国产普通话bbwbbwbbw| 免费91麻豆精品国产自产在线观看| 青青在线精品| 日本福利视频导航| 国产一区二区伦理片| 欧美成人精品欧美一级私黄| 欧美不卡一二三| 久久亚洲资源| 精品在线视频一区二区| 国产欧美在线| 欧美午夜激情影院| 欧美精品视频www在线观看 | 亚洲一级二级在线| 婷婷丁香一区二区三区| 奇米成人av国产一区二区三区| 久久av电影| 中文字幕精品一区二区三区在线| 成人免费在线播放视频| 国产99久一区二区三区a片| 久久99国产精品自在自在app | 日韩女优在线观看| 亚洲欧美制服另类日韩| 日本一区二区电影| 青青草影院在线观看| 不卡av在线免费观看| 免费av网站在线| 日韩小视频在线观看| 亚洲精品午夜| 北条麻妃69av| 国产精品麻豆99久久久久久| 国产精品午夜福利| 91精品国产91久久久久| 国产精品一国产精品| 日本网站在线看| 欧美日韩免费看| 1024免费在线视频| 成人av网站观看| 日韩有码一区二区三区| 波多野结衣家庭教师| 日韩成人在线播放| 日本久久一区| 欧美精品久久久久久久免费| 国产欧美视频一区二区| 亚洲AV无码成人片在线观看| 日本韩国欧美精品大片卡二| 91综合视频| 亚洲国产综合视频| 91精品欧美一区二区三区综合在| 黄在线观看免费网站ktv| 亚洲综合视频一区| 成人动漫中文字幕| 中文字幕在线观看1| 国模私拍视频一区| 五月开心六月丁香综合色啪| 精品黑人一区二区三区观看时间| 欧美巨大另类极品videosbest| sm久久捆绑调教精品一区| 一区二区不卡在线观看| 久久麻豆一区二区| 亚洲国产精彩视频| 国产精自产拍久久久久久| 亚洲欧美视频|