亚洲 国产精品 日韩-亚洲 激情-亚洲 欧美 91-亚洲 欧美 成人日韩-青青青草视频在线观看-青青青草影院

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 最新開(kāi)源:高效的Python通用對(duì)象池化庫(kù)

最新開(kāi)源:高效的Python通用對(duì)象池化庫(kù)

來(lái)源:千鋒教育
發(fā)布人:syq
時(shí)間: 2023-01-13 10:49:00 1673578140

  在程序設(shè)計(jì)中,創(chuàng)建物體模塊主要是通過(guò)生成對(duì)象來(lái)實(shí)現(xiàn)。當(dāng)對(duì)象使用結(jié)束后,則會(huì)成為不再需要的模塊進(jìn)行銷毀。

  而在系統(tǒng)進(jìn)行對(duì)象的生成與銷毀過(guò)程中會(huì)大量的增加內(nèi)存的消耗,同時(shí)對(duì)象的銷毀往往會(huì)留下殘留的信息,這樣將會(huì)伴隨內(nèi)存泄露的問(wèn)題存在。

  在實(shí)際的程序開(kāi)發(fā)過(guò)程中,往往需要生成和銷毀大量重復(fù)的對(duì)象,這就使得內(nèi)存泄漏產(chǎn)生的信息過(guò)多而無(wú)法被系統(tǒng)回收,從而占用系統(tǒng)更多的內(nèi)存,而且生成物體過(guò)多時(shí)無(wú)法確定被什么模塊實(shí)例化實(shí)現(xiàn),對(duì)系統(tǒng)造成負(fù)擔(dān),不利于管理及后續(xù)操作,長(zhǎng)此以往最終將導(dǎo)致程序變慢甚至崩潰。

  對(duì)象池是存放了一批已經(jīng)創(chuàng)建好的對(duì)象的池,它是一個(gè)用來(lái)維護(hù)對(duì)象的結(jié)構(gòu)。當(dāng)程序需要使用對(duì)象的時(shí)候,可以直接從池中獲取該對(duì)象,而不是實(shí)例化一個(gè)新的對(duì)象。

  在程序設(shè)計(jì)過(guò)程中,大部分人關(guān)注的往往只是對(duì)象的使用和效果的實(shí)現(xiàn),實(shí)際上創(chuàng)建和使用之間還有一個(gè)初始化的過(guò)程,不過(guò)系統(tǒng)會(huì)將初始化和創(chuàng)建這兩步結(jié)合在了一起,這樣使得設(shè)計(jì)者忽略了系統(tǒng)創(chuàng)建和銷毀對(duì)象這一過(guò)程對(duì)系統(tǒng)的影響。

  通常來(lái)講,一個(gè)對(duì)象的創(chuàng)建和銷毀過(guò)程開(kāi)銷很小,可以忽略不計(jì),但是如果一個(gè)程序中涉及到一種對(duì)象多次創(chuàng)建,并且創(chuàng)建時(shí)間比較長(zhǎng),那就會(huì)能很明顯的感覺(jué)到這部分的消耗所造成的系統(tǒng)速度受限。

  對(duì)象池可以看作是減少 GC 壓力的首選方法,同時(shí)也是最簡(jiǎn)單的方法。

  對(duì)象池模式主要適用于以下應(yīng)用場(chǎng)景:

  資源受限的場(chǎng)景。比如,不需要可伸縮性的環(huán)境(CPU、內(nèi)存等物理資源有限),CPU性能不夠強(qiáng)勁,內(nèi)存比較緊張,垃圾收集,內(nèi)存抖動(dòng)會(huì)造成比較大的影響,需要提高內(nèi)存管理效率, 響應(yīng)性比吞吐量更為重要。

  在內(nèi)存中數(shù)量受限的對(duì)象。

  創(chuàng)建成本高的對(duì)象。

  大量的存活期短且初始化成本低的對(duì)象池化,以降低內(nèi)存分配和再分配成本,避免內(nèi)存碎片。

  Python 的這樣的動(dòng)態(tài)語(yǔ)言,GC 是依靠引用技術(shù)來(lái)來(lái)保證對(duì)象不會(huì)過(guò)早的回收,某些場(chǎng)景下可能出現(xiàn)雖然創(chuàng)建了但是沒(méi)人使用的空閑期,導(dǎo)致對(duì)象被回收了??梢晕薪o對(duì)象池來(lái)保管。

  Pond 介紹

  Pond 是一個(gè) Python 中高效的通用對(duì)象池,具有性能好、內(nèi)存占用小、命中率高的特點(diǎn)。基于近似統(tǒng)計(jì)的根據(jù)頻率自動(dòng)回收的能力,能夠自動(dòng)調(diào)整每個(gè)對(duì)象池的空閑對(duì)象數(shù)量。

  因?yàn)槟壳?Python 目前沒(méi)有比較好的、測(cè)試用例完備、代碼注釋完備、文檔完善的對(duì)象池化庫(kù),同時(shí)目前的主流對(duì)象池庫(kù)也沒(méi)有比較智能的自動(dòng)回收機(jī)制。

  Pond 可能是 Python 中第一個(gè)社區(qū)公開(kāi)的測(cè)試用例完整,覆蓋率 90% 以上、代碼注釋完備、文檔完善的對(duì)象池化庫(kù)。

  Pond 靈感來(lái)自于 Apache Commons Pool、Netty Recycler、HikariCP、Caffeine,集合了多家的優(yōu)點(diǎn)。

  其次 Pond 通過(guò)使用近似計(jì)數(shù)的方式以極小的內(nèi)存空間統(tǒng)計(jì)每個(gè)對(duì)象池的使用頻率,并且自動(dòng)回收。

  流量較為隨機(jī)平均的情況下,默認(rèn)策略和權(quán)重可以降低 48.85% 內(nèi)存占用,借取命中率 100%。

32

  流量較為符合 2/8 定律的情況下,默認(rèn)策略和權(quán)重可以降低 45.7% 內(nèi)存占用, 借取命中率 100%。

33

  設(shè)計(jì)概述

  Pond 主要由 FactoryDict、Counter、PooledObjectTree 三部分以及一個(gè)單獨(dú)的回收線程構(gòu)成。

  FactoryDict

  使用 Pond 需要實(shí)現(xiàn)對(duì)象工廠 PooledObjectFactory,PooledObjectFactory 提供對(duì)象的創(chuàng)建、初始化、銷毀、驗(yàn)證等操作,由 Pond 調(diào)用。

  所以為了讓對(duì)象池支持存放完全不同的對(duì)象,Pond 使用了一個(gè)字典來(lái)記錄每個(gè)工廠類的名稱和自己實(shí)現(xiàn)的工廠類的實(shí)例化對(duì)象。

  每個(gè) PooledObjectFactory 應(yīng)該具備創(chuàng)建對(duì)象、銷毀對(duì)象、驗(yàn)證對(duì)象是否還可用、重置對(duì)象四個(gè)功能。

  比較特別的是 Pond 支持自動(dòng)重置對(duì)象,因?yàn)槟承﹫?chǎng)景下可能會(huì)存在對(duì)象中要先賦值進(jìn)行傳遞,傳遞完又被回收的情況,為了避免污染建議這種場(chǎng)景下無(wú)比實(shí)現(xiàn)這個(gè)功能。

  Counter

  Counter 中保存了一個(gè)近似計(jì)數(shù)器。

  PooledObjectTree

  PooleedObjectTree 是個(gè)字典,每個(gè) key 對(duì)應(yīng)著一個(gè)先進(jìn)先出的隊(duì)列,這些隊(duì)列都是線程安全的。

  每個(gè)隊(duì)列中保存著多個(gè) PooleedObject。PooledObejct 保存了創(chuàng)建時(shí)間、最后借出的時(shí)間以及實(shí)際需要的對(duì)象。

  線程安全

  Pond 的借用和回收都是線程安全的。Python 的 queue 模塊提供了一個(gè)適用于多線程編程的先進(jìn)先出(FIFO)數(shù)據(jù)結(jié)構(gòu)。它可以用來(lái)安全地在生產(chǎn)者和消費(fèi)者線程之間傳遞消息或其他數(shù)據(jù)。

  鎖是調(diào)用者來(lái)處理的,所有多個(gè)線程能夠安全且容易的使用同樣的 Queue 實(shí)例工作。而 Pond 的借用和回收都是在操作 queue,所以基本可以認(rèn)為是線程安全的。

  借出機(jī)制

  在使用 Pond 借出一個(gè)對(duì)象時(shí),會(huì)先檢查想要借出的對(duì)象的種類是否已經(jīng)在 PooledObjectTree 存在,如果存在會(huì)檢查這個(gè)對(duì)象的對(duì)象池是否為空,如果為空會(huì)創(chuàng)建一個(gè)新的。

  如果對(duì)象池中有多余的對(duì)象,會(huì)利用 queue 彈出一個(gè)對(duì)象并驗(yàn)證這個(gè)對(duì)象是否可用。如果不可用會(huì)自動(dòng)調(diào)用所屬的 Factory 清理銷毀該對(duì)象,同時(shí)清理它在 Python 中的 GC 計(jì)數(shù),讓它更快被 GC 回收,不斷拿取下一個(gè)直至有可用的。

  如果這個(gè)對(duì)象可用,則會(huì)直接返回。當(dāng)然無(wú)論是從對(duì)象池中取出對(duì)象還是新創(chuàng)建了一個(gè)對(duì)象,都會(huì)利用 Counter 增加一個(gè)計(jì)數(shù)。

  回收機(jī)制

  回收一個(gè)對(duì)象時(shí)會(huì)判斷目標(biāo)對(duì)象池存不存在,如果存在會(huì)檢查對(duì)象池是否已經(jīng)滿了,滿了的話會(huì)自動(dòng)銷毀要?dú)w還的這個(gè)對(duì)象。

  然后會(huì)檢查這個(gè)對(duì)象是否已經(jīng)被借出太長(zhǎng)時(shí)間,如果超過(guò)了配置的最長(zhǎng)時(shí)間同樣會(huì)被清理掉。

  自動(dòng)回收

  自動(dòng)回收時(shí)每隔一段時(shí)間,默認(rèn)是 300 s,就會(huì)執(zhí)行一次。自動(dòng)清理不經(jīng)常使用的對(duì)象池中的對(duì)象。

  使用說(shuō)明

  你可以先安裝 Pond 的庫(kù)并且在你的項(xiàng)目中引用。

pip install pondpond

from pond import Pond, PooledObjectFactory, PooledObject

  首先你需要聲明一個(gè)你想要放入的類型的對(duì)象的工廠類,比如下面的例子我們希望池化的對(duì)象是 Dog,所以我們先聲明一個(gè) PooledDogFactory 類,并且實(shí)現(xiàn) PooledObjectFactory。

class Dog:
    name: str
    validate_result:bool = True


class PooledDogFactory(PooledObjectFactory):
    def creatInstantce(self) -> PooledObject:
        dog = Dog()
        dog.name = "puppy"
        return PooledObject(dog)

    def destroy(self, pooled_object: PooledObject):
        del pooled_object

    def reset(self, pooled_object: PooledObject) -> PooledObject:
        pooled_object.keeped_object.name = "puppy"
        return pooled_object

    def validate(self, pooled_object: PooledObject) -> bool:
        return pooled_object.keeped_object.validate_result

  接著你需要?jiǎng)?chuàng)建 Pond 的對(duì)象:

pond = Pond(borrowed_timeout=2,
            time_between_eviction_runs=-1,
            thread_daemon=True,
            eviction_weight=0.8)

  Pond 可以傳遞一些參數(shù)進(jìn)去,分別代表:

  borrowed_timeout :?jiǎn)挝粸槊耄璩鰧?duì)象的最長(zhǎng)期限,超過(guò)期限的對(duì)象歸還時(shí)會(huì)自動(dòng)銷毀不會(huì)放入對(duì)象池。

  time_between_eviction_runs :?jiǎn)挝粸槊耄詣?dòng)回收的間隔時(shí)間。

  thread_daemon :守護(hù)線程,如果為 True,自動(dòng)回收的線程會(huì)隨著主線程關(guān)閉而關(guān)閉。

  eviction_weight :自動(dòng)回收時(shí)權(quán)重,會(huì)將這個(gè)權(quán)重與最大使用頻次想乘,使用頻次小于這個(gè)值的對(duì)象池中的對(duì)象都會(huì)進(jìn)入清理步驟。

  實(shí)例化工廠類:

factory = PooledDogFactory(pooled_maxsize=10, least_one=False)

  所有繼承了 PooledObjectFactory 都會(huì)自帶構(gòu)造函數(shù),可以傳遞 pooled_maxsize 和 least_one 兩個(gè)參數(shù)。

  pooled_maxsize:這個(gè)工廠類生成出的對(duì)象的對(duì)象池的最大能放置的數(shù)量。

  least_one:如果為 True,在進(jìn)入自動(dòng)清理時(shí),這個(gè)工廠類生成出的對(duì)象的對(duì)象池會(huì)至少保留一個(gè)對(duì)象。

  向 Pond 注冊(cè)這個(gè)工廠對(duì)象,默認(rèn)會(huì)使用 factory 的類名作為 PooledObjectTree 的 key :

pond.register(factory)

  當(dāng)然你也可以自定義它的名字,名字會(huì)作為 PooledObjectTree 的 key:

pond.register(factory, name="PuppyFactory")

  注冊(cè)成功后,Pond 會(huì)自動(dòng)根據(jù) factory 中設(shè)置的 pooled_maxsize 自動(dòng)開(kāi)始創(chuàng)建對(duì)象直至填滿這個(gè)對(duì)象池。

  借用和歸還對(duì)象:

pooled_object: PooledObject = pond.borrow(factory)
dog: Dog = pooled_object.use()
pond.recycle(pooled_object, factory)

  當(dāng)然你可以用名字來(lái)進(jìn)行借用和歸還:

pooled_object: PooledObject = pond.borrow(name="PuppyFactory")
dog: Dog = pooled_object.use()
pond.recycle(pooled_object, name="PuppyFactory")

  完全清理一個(gè)對(duì)象池:

pond.clear(factory)

  通過(guò)名字清理一個(gè)對(duì)象池:

pond.clear(name="PuppyFactory")

  正常情況下,你只需要使用上面的這些方法,生成對(duì)象和回收對(duì)象都是全自動(dòng)的。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
工業(yè)機(jī)器人、自動(dòng)化、PLC三者是什么關(guān)系?

一、工業(yè)機(jī)器人和自動(dòng)化工業(yè)機(jī)器人是自動(dòng)化技術(shù)的一部分,是自動(dòng)化生產(chǎn)線的關(guān)鍵組件之一。在自動(dòng)化生產(chǎn)線中,工業(yè)機(jī)器人被廣泛應(yīng)用于執(zhí)行各種任...詳情>>

2023-10-15 01:41:38
為什么Redis要對(duì)一種數(shù)據(jù)類型存儲(chǔ)兩次呢?

一、實(shí)現(xiàn)快速數(shù)據(jù)訪問(wèn)Redis是一種高性能的內(nèi)存數(shù)據(jù)庫(kù),將數(shù)據(jù)存儲(chǔ)在內(nèi)存中可以實(shí)現(xiàn)非??焖俚臄?shù)據(jù)讀取和訪問(wèn)。為了進(jìn)一步提高數(shù)據(jù)的訪問(wèn)速度,R...詳情>>

2023-10-15 01:40:32
什么是編程思想?

一、編程思想的定義和理念編程思想可以理解為一套指導(dǎo)編程活動(dòng)的理念和原則。它包括如何定義問(wèn)題,如何設(shè)計(jì)解決方案,以及如何實(shí)現(xiàn)和測(cè)試這個(gè)解...詳情>>

2023-10-15 01:22:38
迭代開(kāi)發(fā)模型中最容易出問(wèn)題的階段是什么?

一、迭代開(kāi)發(fā)模型中最容易出問(wèn)題的階段是什么 在迭代開(kāi)發(fā)模型中,最容易出問(wèn)題的階段通常是需求收集和分析階段。在這個(gè)階段,開(kāi)發(fā)團(tuán)隊(duì)需要與客...詳情>>

2023-10-15 01:03:52
軟件測(cè)試中bug管理工具Jira怎么樣?

一、Jira是什么 Jira是一款由澳大利亞軟件公司Atlassian開(kāi)發(fā)的項(xiàng)目管理和問(wèn)題跟蹤工具。它是一種用于敏捷項(xiàng)目開(kāi)發(fā)和軟件開(kāi)發(fā)過(guò)程中的工具,廣泛...詳情>>

2023-10-15 01:02:32
快速通道
亚洲中文字幕无码日韩| 亚洲人成网站观看在线播放| 亚洲国产成人无码AV在线影院L | 亚洲国产精品久久久久婷婷软件| 用嘴巴吃鸡的好处| 草棚CAOPORON已满18进| 国产日产欧产精品精品蜜芽| 久久无码AV三级| 日产无人区一线二线三线观看| 无码精品人妻一区二区三区人妻斩 | 久久无码人妻丰满熟妇区毛片| 欧美性色黄大片手机版| 五十路丰满中年熟女中出| 一区二区三区AV在线| 成片人卡1卡2卡3手机免费看| 国产午夜精品一区二区三区老 | JAPANESE熟女熟妇| 国产精品美女被操| 久久亚洲私人国产精品VA| 日韩加勒比一本无码精品| 亚洲AV永久青草无码精品| 中文字幕人乱码中文字幕| 丰满多毛的陰户视频| 久久国产精品一国产精品金尊| 欧洲美熟女乱又伦AV| 亚洲AV成人综合网| 91人妻中文字幕在线精品| 国产精品无码久久久久| 免费人成视频X8X8入口| 无码超级大爆乳在线播放 | 老赵揉搓苏清雅双乳| 色窝窝无码一区二区三区成人网站| 亚洲第一AV无码专区| 啊轻点灬大JI巴太粗太长了H文| 国产无遮挡又黄又爽又色| 嫩BBB槡BBBB搡BBBB| 性色AV浪潮AV色欲AV| 69女性XXXXⅩ丰满HD| 国产欧美精品一区二区三区-老狼 国产欧美精品一区二区三区 | 美国6一12呦女精品| 无码一区二区三区久久精品| 51国产偷自视频区视频| 国产又爽又黄又无遮挡的激情视频| 欧美精品一区二区| 亚洲AV香蕉一区区二区三区| 暗夜免费观看在线完整版| 精品国产乱码一区二区三区 | 东京热人妻丝袜AV无码| 久久一日本道色综合久久| 无码国内精品久久人妻蜜桃| 99无人区卡一卡二卡三乱码| 狠狠色噜噜狠狠狠狠97| 色妞AV永久一区二区国产AV开| 一本无码中文字幕在线观| 国产极品视觉盛宴专区| 欧洲无线一线二线三W955| 亚洲人成无码网站| 国产成人午夜无码电影在线观看| 女教师娇喘潮喷抽搐在线视频| 亚洲成AV成人片在线观看| 道德沦丧一家3口小说| 免费无人区一码二码乱码| 亚洲AV无码一区二区三区蜜桃| 成人精品免费视频在线观看| 麻豆国产96在线 | 日韩| 亚洲AV中文AⅤ无码AV接吻| 福利乱码卡一卡二卡新区| 免费无码又爽又刺激高潮的漫画| 亚洲MV砖码砖区2021在线| 俄罗斯VIDEODESEXO极| 欧美成人精品激情在线观看| 亚洲欧美日本韩国| 国产麻豆MD传媒视频| 日韩AV无码精品人妻系列| 51VV社区视频在线视频观看| 久久国产中文娱乐网| 亚洲AⅤ无码一级毛片孕交| 疯狂做受ⅩXXX高潮欧美| 欧美人与禽Z0ZO牲伦交| 又粗又大又黄又爽的免费视频| 激情综合色五月丁香六月亚洲| 天天大片天天看大片| 暴躁老阿姨CSGO攻略大全| 男人边吃奶边做呻吟免费视频| 亚洲熟妇AV日韩熟妇AV| 国内揄拍国内精品少妇国语| 玩稚嫩的小屁股眼AV| 处破女处破全过程| 强伦姧人妻三上悠亚中文字幕| 中文字幕AV伊人AV无码AV| 久久人与动人物A级毛片| 亚洲人成人无码www五月婷| 国产又粗又湿又刺激18禁| 无码欧精品亚洲日韩一区| 高潮动态图啪啪吃奶图动态| 人人爽人人澡人人高潮| JAVASCRIPT的成熟分类| 女人扒开腿让男人狂桶30分钟| 征服好友的保守人妻| 久久婷婷人人澡人人爽人人喊| 亚洲码欧美码一区二区三区| 黑人人妻AV一区二区三| 亚洲AV无码二区一区二十六区 | 麻豆星空传媒果冻传媒大象| 亚洲中文字幕在线第六区| 精品香蕉一区二区三区| 亚洲精品久久久久久中文字幕| 韩国精品一区二区无码视频| 亚洲AV成人无码网站大全唐人 | 内射无码专区久久亚洲| 综合精品欧美日韩国产在线| 猫咪WWW免费人成人入口| 正在播放老肥熟妇露脸| 免费的最近直播比较火的黄台 | 国产精品自在拍一区二区不卡| 玩小雪跪趴把腿分到最大影视频| 国产成人综合在线观看不卡| 未成满18禁止免费无码网站| 国产成人无码精品XXXX网站| 天天躁夜夜躁狠狠是什么心态| 国产成人精品亚洲一区二区三区| 玩两个丰满老熟女| 国产欧美精品一区二区色综合| 亚欧乱色熟女一区二区三区| 国内精品久久久久久久97牛牛 | 熟女少妇a性色生活片毛片| 国产成人A区在线观看| 无码天堂亚洲国产AV| 国产亚洲AV☆浪潮在线观看 | 性妇WBBBB搡BBBB嗓1| 国产一区二区三区在线电影| 亚洲AV综合伊人AV一区加勒比 | 中文国产成人精品久久不卡| 女生让男生随便诵自己的名字| 97久久精品人妻人人搡人人玩| 欧美日韩精品一区二区三区不卡 | 亚洲AV成人无码网站在线 | 野花韩国视频在线观看免费高清 | 好爽又高潮了毛片| 亚洲日韩V无码中文字幕| 浪潮AV激情高潮国产精品没电了| 13学生小美女洗澡裸体视频| 全免费A级毛片免费看视频| 公交车上荫蒂添的好舒服口述小说 | 国产裸模视频免费区无码| 亚洲高清乱码午夜电影网| 久久久久久亚洲AV成人无码国产| 18禁超污无遮挡无码免费游戏 | 欧美日韩一区二区三区精品视频在线 | 99国产欧美久久久精品蜜芽 | 欧美成人高清WW| 成色AU999.9是什么意思| 无码精品一区二区三区免费视频| 和老婆一起玩的双人| 亚洲中文久久精品无码软件| 欧美高清VIVO最新| 高清国产天干天干天干| 亚洲阿V天堂无码Z2018| 蜜桃人妻一区二区三区| 成人网站WWW污污污网站| 性色a∨精品高清在线观看| 久久无码AV中文出轨人妻| VODAFONEWIFI巨大黑| 无码人妻精品一区二区蜜桃百度 | 娇小性XXXX摘花HD| 18禁裸乳啪啪无遮裆网站| 上课我穿超短裙被同桌摸出水 | 三个人一起玩3Q详细经过| 国产性生大片免费观看性| 又大又粗又爽又黄的少妇毛片| 人妻无码人妻有码中文字幕在线| 国产成人MV视频在线观看| 亚洲人亚洲精品成人网站| 欧美一级 片内射黑人B| 国产精品毛多多水多| 一边亲着一面膜下奶韩剧| 日韩成视频在线精品| 精品国产AV色欲果冻传媒| FUCK东北老熟女人HD叫床| 小婷又软又嫩又紧水又多的软件 | 中文字幕乱码一区二区三区免费 | 3D动漫精品啪啪一区二区中| 特级毛片爽WWW免费版| 久久精品国产亚洲A∨麻豆| 锕锕锕锕锕~好深啊APP网站| 午夜丰满少妇性开放视频| 蜜桃AV噜噜一区二区三区| 国产 麻豆 日韩 欧美 久久| 夜夜高潮夜夜爽高清完整版1 | 亚洲色偷偷偷网站色偷一区人人澡| 欧美熟妇成人大片性爽| 国产熟女露脸大叫高潮| 99精品电影一区二区免费看| 性一交一乱一伦一在线小视频 | 亚洲暴爽AV人人爽日日碰| 欧美肉体裸交做爰XXXⅩ性玉| 国产偷久久久精品专区| 2019理论韩国理论中文| 新狼窝色AV性久久久久久| 欧美人C交ZOOZOOXX|