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

用戶數十億的iOS超級應用,10年代碼變化,你發現了嗎?

原創 精選
移動開發 iOS
FBiOS架構演變到今天,并不是有意為之的。它反映了10年以來的發展,這是由越來越多的工程師開發該App所需的技術決策、穩定性以及最重要的用戶體驗所推動的。

?作者 | Dustin Shahidehpour

策劃 | 言征 

iOS版Facebook(FBiOS)可以說是Meta最古老的移動代碼庫了。自2012年該應用程序被重寫以來,數千名工程師對其進行了研究,并將其交付給數十億用戶,它可以支持數百名工程師一次對其進行迭代。

FBiOS架構演變到今天,并不是有意為之的。它反映了10年以來的發展,這是由越來越多的工程師開發該App所需的技術決策、穩定性以及最重要的用戶體驗所推動的。

補充知識:

截止到2022年,該代碼庫已經走過了十周年,筆者將對這一演變背后的技術決策以及它們的歷史背景進行一些說明。

經過多年的迭代,Facebook代碼庫與典型的iOS代碼庫不同:

(1)它包含了C++、Objective-C(++)和Swift。

(2)它有幾十個動態加載的庫(dylib),以及太多的類,無法一次將它們加載到Xcode中。

(3)蘋果SDK的原始使用幾乎為零——一切都被內部抽象所包裝或替換。

(4)該應用程序大量使用代碼生成,這是由我們的自定義構建系統 Buck 推動的。

(5)如果我們的構建系統沒有大量緩存,工程師將不得不花一整天時間等待應用程序的構建。  

一、2014:建立我們自己的移動框架

2014年,對Facebook應用程序進行本地重寫已經過去兩年,這時,News Feed的代碼庫開始出現可靠性問題。當時,News Feed的數據模型得到了蘋果管理數據模型的默認框架:核心數據的支持。核心數據中的對象是可變的,這并不適合新聞提要的多線程架構。更糟糕的是,News Feed利用了雙向數據流,這源于它對Cocoa應用程序使用了蘋果事實上的設計模式:模型視圖控制器。

最終,這種設計加劇了不確定性代碼的產生,這些代碼很難調試或再現錯誤。很明顯,這種架構是不可持續的,是時候重新思考了。

在考慮新的設計時,一位工程師研究了React,Facebook的(開源)UI框架,該框架在Javascript社區中非常流行。React的聲明性設計抽象了導致Feed(在web上)出現問題的棘手命令式代碼,并利用了單向數據流,這使得代碼更易于推理。這些特征似乎很適合News Feed面臨的問題:蘋果的SDK中沒有聲明性UI。

Swift將在幾個月內發布,SwiftUI(蘋果的聲明性UI框架)將在2019年之前發布。如果NewsFeed想要有一個聲明性UI,那么團隊必須構建一個新的UI框架。

最終,這就是他們所做的。

在花了幾個月時間構建和遷移新聞提要以在新的聲明性UI和新的數據模型上運行后,FBiOS的性能提高了50%。

幾個月后,他們開源了基于React的移動UI框架ComponentKit。時至今日,ComponentKit仍然是在Facebook中構建本機UI的事實上的選擇。它通過視圖重用池、視圖展平和背景布局計算為應用程序提供了無數性能改進。它也啟發了其Android對手Litho和SwiftUI。

最終,選擇用自定義infra替換UI和數據層是一種權衡。為了獲得可以可靠維護的令人愉快的用戶體驗,新員工必須擱置他們對Apple API的行業知識,學習定制的內部基礎設施。

這將不是FBiOS最后一次做出平衡最終用戶體驗與開發者體驗和速度的決定。進入2015年,該應用的成功將引發我們所稱的功能爆炸。這也帶來了一系列獨特的挑戰。

二、2015:架構拐點

到2015年,Meta在其“移動第一”的口號上翻了一番,FBiOS代碼庫的每日貢獻者數量急劇增加。隨著越來越多的產品被集成到應用程序中,其發布時間開始縮短,人們開始注意到。到2015年底,啟動性能非常緩慢(接近30秒!),以至于有可能被手機的操作系統殺死。

經過調查,很明顯有許多因素導致啟動性能下降。為了簡潔起見,我們將只關注那些對應用程序架構有長期影響的方面:

(1)隨著應用程序的規模隨著每種產品的增長而增長,該應用程序的“前置”時間正在以無限的速度增長。

(2)該應用程序的“模塊”系統為每個產品提供了對該應用程序所有資源的無管制訪問。這導致了一個公共問題的悲劇,因為每個產品都利用它的“鉤子”來啟動,以執行計算上昂貴的操作,從而快速導航到該產品。

緩解和改善啟動所需的更改將從根本上改變產品工程師為FBiOS編寫代碼的方式。

三、2016年:Dylibs和模塊化

根據蘋果關于改進發布時間的維基,在調用應用程序的“主”功能之前,必須執行許多操作。通常,一個應用程序的代碼越多,所需時間就越長。

雖然“pre-main”在發布過程中僅貢獻了30秒的一小部分時間,但這是一個特別令人擔憂的問題,因為隨著FBiOS不斷積累新功能,它將繼續以無限的速度增長。

為了幫助緩解應用程序發布時間的無限增長,我們的工程師開始將大量產品代碼移入一個稱為動態庫(dylib)的延遲加載容器中。當代碼移動到動態加載的庫中時,不需要在應用程序的main()函數之前加載。

最初,FBiOS dylib結構如下:

圖片

創建了兩個產品dylib(FBCamera和NotOnStartup),第三個dylib(FBShared)用于在不同的dylib和主應用程序的二進制文件之間共享代碼。

dylib溶液效果很好。FBiOS能夠抑制應用程序啟動時間的無限增長。隨著時間的推移,大多數代碼都會以dylib結尾,這樣啟動時的性能就會保持快速,并且不會受到應用程序中添加或刪除產品的持續波動的影響。

dylibs的加入引發了Meta產品工程師編寫代碼方式的思想轉變。隨著dylib的添加,像NSClassFromString()這樣的運行時API冒著運行時失敗的風險,因為所需的類存在于卸載的dylib中。由于FBiOS的許多核心抽象都是在遍歷內存中的所有類的基礎上構建的,因此FBiOS必須重新思考其核心系統的工作情況。

除了運行時失敗之外,dylibs還引入了一類新的鏈接器錯誤。如果Facebook(啟動集)中的代碼引用了dylib中的代碼,工程師將看到如下鏈接器錯誤:

Undefined symbols for architecture arm64:
"_OBJC_CLASS_$_SomeClass", referenced from:
objc-class-ref in libFBSomeLibrary-9032370.a(FBSomeFile.mm.o)

為了解決這個問題,工程師們需要用一個特殊的函數來包裝他們的代碼,如果需要的話,可以加載dylib,比如:

int main() {
DoSomething(context);
}

看起來像這樣:
int main() {
FBCallFunctionInDylib(
NotOnStatupFramework,
DoSomething,
context
);
}

該解決方案有效,但有很多奇怪的地方:

(1)應用程序特定的dylib枚舉被硬編碼到各種調用站點中。Meta的所有應用程序都必須共享一個dylib枚舉,讀者有責任確定代碼運行的應用程序是否使用了該dylib。

(2)如果使用了錯誤的dylib枚舉,代碼將失敗,但僅在運行時失敗。考慮到應用程序中大量的代碼和功能,這個延遲的信號導致了開發過程中的許多挫折。

最重要的是,我們唯一能防止在啟動過程中引入這些調用的系統是基于運行時的,在應用程序引入最后一分鐘的回歸時,許多發布都被延遲。

最終,dylib優化抑制了應用程序發布時間的無限增長,但這意味著應用程序架構的巨大轉折點。FBiOS工程師將在接下來的幾年里重新設計應用程序,以消除dylib帶來的一些粗糙邊緣,我們(最終)推出了一個比以往任何時候都更強大的應用程序架構。

四、2017:重新思考FBiOS架構

隨著dylibs的引入,FBiOS的幾個關鍵組件需要重新思考:

(1)“模塊注冊系統”不能再基于運行時。

(2)工程師們需要一種方法來了解啟動期間的任何代碼路徑是否會觸發dylib加載。

(3)為了解決這些問題,FBiOS轉向Meta的開源構建系統Buck。

在Buck中,每個“目標”(app、dylib、library等)都用一些配置聲明,如下所示:

apple_binary(
name = "Facebook",
...
deps = [
":NotOnStartup#shared",
":FBCamera#shared",
],
)

apple_library(
name = "NotOnStartup",
srcs = [
"SomeFile.mm",
],
labels = ["special_label"],
deps = [
":PokesModule",
...
],
)

每個“目標”都列出了構建它所需的所有信息(依賴項、編譯器標志、源等),當調用“buck build”時,它會將所有這些信息構建成一個可以查詢的圖形。

$ buck query “deps(:Facebook)
> :NotOnStartup
> :FBCamera

$ buck query “attrfilter(labels, special_label, deps(:Facebook))
> :NotOnStartup

使用這個核心概念(以及一些特殊的醬汁),FBiOS開始生成一些buck查詢,這些查詢可以在構建過程中生成應用程序中的類和函數的整體視圖。這些信息將成為該應用程序下一代架構的基石。

五、2018:生成代碼的激增

既然FBiOS能夠利用Buck查詢依賴關系中的代碼信息,那么它就可以創建一個“function/classes->dylibs”的映射,可以在運行中生成。

{
"functions": {
"DoSomething": Dylib.NotOnStartup,
...
},
"classes": {
"FBSomeClass": Dylib.SomeOtherOne
}
}

使用該映射作為輸入,FBiOS使用它生成從調用站點抽象出dylib枚舉的代碼:

static std::unordered_map<const char *, Dylib> functionToDylib {{
{ "DoSomething", Dylib.NotOnStartup },
{ "FBSomeClass", Dylib.SomeOtherOne },
...
}};

左右滑動查看完整代碼

使用代碼生成之所以吸引人,有幾個原因:

(1)因為代碼是基于本地輸入重新生成的,所以沒有什么可簽入的,也沒有更多的合并沖突!考慮到FBiOS的工程規模每年都會翻倍,這是一個巨大的開發效率勝利。

(2)不再需要應用程序特定的dylib(因此可以重命名為“FBCallFunction”)。相反,調用將從構建期間為每個應用程序生成的靜態映射中讀取。

事實證明,將Buck查詢與代碼生成相結合是如此成功,以至于FBiOS將其作為新插件系統的基礎,最終取代了基于運行時的應用程序模塊系統。

1.左移信號

使用Buck支持的插件系統。FBiOS能夠通過將infra遷移到基于插件的架構中,以構建時警告取代大多數運行時失敗。

構建FBiOS時,Buck可以生成一個圖表,顯示應用程序中所有插件的位置,如下所示:

圖片

從這個角度來看,插件系統可以顯示構建時間錯誤,以便工程師發出警告:

(1)“插件D、E可能會觸發dylib加載。這是不允許的,因為這些插件的調用方位于應用程序的啟動路徑中。”

(2)“應用程序中沒有用于呈現配置文件的插件……這意味著導航到該屏幕將無法工作?!?/p>

(3)“有兩個插件用于呈現組(插件A、插件B)。其中一個應該刪除。”

對于舊的應用程序模塊系統,這些錯誤將是“懶惰”的運行時斷言?,F在,工程師們相信,當FBiOS成功構建時,它不會因為功能缺失、應用程序啟動期間的dylib加載或模塊運行時系統中的不變量而失敗。

2.代碼生成的代價

雖然將FBiOS遷移到插件系統提高了應用程序的可靠性,為工程師提供了更快的信號,并使應用程序可以與其他移動應用程序輕松共享代碼,但這是有代價的:

(1)插件錯誤在Stack Overflow上很難找到答案,調試時會感到有些吃力。

(2)基于代碼生成和Buck的插件系統與傳統的iOS開發有著天壤之別。

(3)插件為代碼庫引入了一層中間層。大多數應用程序都會有一個包含所有功能的注冊表文件,這些都是在FBiOS中生成的,很難找到。

毫無疑問,插件使FBiOS遠離了慣用的iOS開發,但這種權衡似乎是值得的。我們的工程師可以更改Meta的許多應用程序中使用的代碼,并確保如果插件系統運行良好,任何應用程序都不會因缺少很少測試的代碼路徑中的功能而崩潰。像News Feed和Groups這樣的團隊可以為插件構建一個擴展點,并確保產品團隊可以在不觸及核心代碼的情況下集成到其表面。

六、2020:Swift與語言架構

應用程序規模問題導致的架構變化上,但蘋果SDK的變化也迫使FBiOS重新考慮其一些架構決策。

2020年,FBiOS開始看到來自蘋果的Swift專用API的數量增加,并且越來越多的人希望在代碼庫中使用更多的Swift。終于是時候接受這樣一個事實了:Swift是FB應用程序中不可避免的租戶。

歷史上,FBiOS曾使用C++作為構建抽象的杠桿,因為C++的“零開銷”原則,這節省了代碼大小。但C++尚未與Swift互操作。對于大多數FBiOS API(如ComponentKit),必須創建某種墊片以在Swift中使用,從而導致代碼膨脹。

下面是一個圖表,概述了代碼庫中的問題:

圖片

考慮到這一點,我們開始形成一種關于何時何地使用各種代碼的語言策略:

圖片

最終,FBiOS團隊開始建議:面向產品的API/代碼不應包含C++,這樣我們就可以自由使用蘋果公司的Swift和未來的Swift API。使用插件,FBiOS可以抽象出C++實現,這樣它們仍然為應用提供動力,但對大多數工程師來說是隱藏的。

這種類型的工作流意味著FBiOS工程師構建抽象的方式發生了一些變化。自2014年以來,影響框架構建中的最大因素是對應用程序大小和表現力的貢獻度(這就是為什么ComponentKit選擇Objective-C++而不是Objective-C的原因)。

Swift的引入導致開發人員的效率降低,不急,未來還能看到更多。

七、2022年:旅程已完成1%

自2014年以來,FBiOS架構發生了很大變化:

(1)它引入了大量內部抽象,如ComponentKit和GraphQL。

(2)它使用dylibs將“pre-main”時間保持在最小,并有助于快速啟動應用程序。

(3)它引入了一個插件系統(由Buck提供支持),這樣就可以從工程師那里抽象出dylib,因此代碼很容易在應用程序之間共享。

(4)它引入了關于何時何地使用各種語言的語言指南,并開始改變代碼庫以反映這些語言指南。

與此同時,蘋果對其手機、操作系統和SDK進行了令人興奮的改進:

(1) 他們的新手機速度很快。裝載成本比以前小得多。

(2) dyld3和鏈修復等操作系統改進提供了軟件,使代碼加載更快。

(3) 他們引入了SwiftUI,這是一個用于UI的聲明性API,它與ComponentKit共享了很多概念。

(4) 他們提供了改進的SDK,以及我們可以為其構建自定義框架的API(如iOS8中的可中斷動畫)。

隨著Facebook、Messenger、Instagram和WhatsApp分享了更多的體驗,FBiOS正在重新審視所有這些優化,以了解在哪些方面可以更接近平臺正統。最終,我們發現,共享代碼的最簡單方法是使用應用程序免費提供的東西,或者構建一個幾乎無依賴性且可以在所有應用程序之間集成的東西。

我們將于2032年在這里與您見面,回顧代碼庫的20周年紀念!?

責任編輯:武曉燕 來源: 51CTO技術棧
相關推薦

2010-11-04 10:06:27

GSMMTN華為

2024-05-20 08:25:55

2014-08-21 14:49:32

MIUI 6

2015-07-21 15:35:47

代碼總結源碼

2020-09-01 10:32:52

iOS微信新功能

2022-04-26 06:43:12

文檔TCPLinux

2016-10-24 15:44:15

2022-04-18 07:42:31

配置機制Spring

2020-08-17 09:30:34

代碼焦點程序員

2018-01-24 11:49:34

2015-11-16 14:52:13

代碼程序員

2018-08-22 09:01:08

2015-01-05 09:56:41

UDPLinux TCP

2020-04-14 15:30:00

微信群管理朋友圈

2012-02-23 13:34:28

2025-09-12 11:00:00

Akamai云計算安全

2018-07-12 14:03:33

區塊鏈新零售電子商務

2011-03-25 15:21:43

點贊
收藏

51CTO技術棧公眾號

四虎精品欧美一区二区免费| 亚洲xxx拳头交| 久久久久久夜| 欧美一卡二卡三卡| 日本国产精品视频| 久久精品一卡二卡| 成年人在线观看网站| 乱中年女人伦av一区二区| 国产精品美女久久久久久2018| 国产+成+人+亚洲欧洲| 亚洲三级在线观看视频| 国产精品久久久久一区二区国产 | 久久aⅴ国产紧身牛仔裤| 夜夜躁日日躁狠狠久久88av | 国产欧美短视频| 欧美精品xxxxbbbb| 日韩精品不卡| 国产成人在线免费视频| 北条麻妃在线一区二区免费播放| 亚洲图片激情小说| 国产日韩精品在线| 精品国产aaa| 草莓视频成人appios| 国产午夜精品在线观看| 国产成人精品av在线| 波多野结衣办公室33分钟| 两个人看的在线视频www| 粉嫩一区二区三区性色av| 欧美超级乱淫片喷水| 久久精品一二三四| 亚洲电影视频在线| 国产99久久久国产精品潘金网站| 国产精品福利小视频| 日本一二三不卡视频| 加勒比色综合久久久久久久久| 欧美日韩成人在线一区| 午夜在线视频免费观看| 国产伦精品一区二区三区四区| 国产精品18hdxxxⅹ在线| 亚洲一区二区三区三| 国产精品大全| 欧美日韩综合在线观看| 911久久香蕉国产线看观看| 亚洲欧美精品suv| 91日韩视频在线观看| 香蕉视频国产在线观看| 国产另类ts人妖一区二区| 久久高清视频免费| 69xxx免费| 国产精品一区二区三区av麻| 欧美精品亚洲一区二区在线播放| 白嫩少妇丰满一区二区| 97视频精彩视频在线观看| 黄色日韩网站视频| 久久人人爽国产| 国产又黄又爽又无遮挡| 红杏aⅴ成人免费视频| 日韩欧美一区在线观看| 欧美 日韩 国产在线观看| 国产中文字幕在线视频| 久久福利视频一区二区| 欧美黑人狂野猛交老妇| 国产又粗又猛又爽视频| 久久91视频| 亚洲综合色婷婷| 欧美成人一区二区在线| 一级欧美一级日韩| 亚洲巨乳在线| 主播福利视频一区| 国产精品91av| av在线一区不卡| 欧洲一区二区三区在线| www.18av.com| 国产中文在线| 亚洲国产经典视频| 国产女人水真多18毛片18精品 | 国产精品私拍pans大尺度在线| 日韩a级片在线观看| 亚洲国产合集| 日韩欧美国产小视频| 中文字幕av一区二区三区人妻少妇| av中文字幕在线观看第一页| 国产精品入口麻豆原神| 在线看成人av电影| 欧美香蕉爽爽人人爽| 国产一区二区三区蝌蚪| 日韩av免费在线看| 久草国产在线观看| 日韩三级在线| 亚洲老头同性xxxxx| 无码少妇一区二区| 日韩丝袜视频| 精品久久免费看| www.久久久久久久久久久| 亚洲91网站| 欧美精品高清视频| 中文字幕在线国产| 成人精品视频在线观看| 欧美亚洲综合在线| 99爱视频在线| sm久久捆绑调教精品一区| 亚洲精品国产精华液| 亚洲图片小说在线| 成人网视频在线观看| 中文字幕综合网| 亚洲日本精品国产第一区| 操你啦视频在线| 综合久久久久久| 国产老熟妇精品观看| 国模雨婷捆绑高清在线| 亚洲另类一区二区| 97精品国产97久久久久久粉红| 超碰免费在线| 亚洲午夜久久久久久久久电影院| 黄色av免费在线播放| 美脚恋feet久草欧美| 欧美视频在线观看 亚洲欧| 你真棒插曲来救救我在线观看| 色操视频在线| 在线精品视频一区二区三四| 中国男女全黄大片| 97在线精品| 久久精品国产综合| 永久免费看片视频教学| 国产精品99久久| 久久在线精品视频| avove在线播放| 日韩高清电影一区| 国产又爽又黄的激情精品视频| 亚洲黄色在线播放| 成人av在线影院| 久久av二区| 国产毛片av在线| 午夜精品一区二区三区电影天堂 | 麻豆tv入口在线看| 国产精品色婷婷久久58| 男人操女人免费软件| 国产精品99蜜臀久久不卡二区| 天天躁日日躁狠狠躁伊人| 26uuu精品一区二区| 欧美综合77777色婷婷| 91社区在线观看播放| 欧美性极品xxxx娇小| 天堂网成人在线| 久久精品国内一区二区三区水蜜桃| 国产97在线|亚洲| 日韩大胆人体| 岛国av一区二区三区| 中文字幕第21页| 九九热线有精品视频99| 日韩在线视频播放| 日本三级欧美三级| 久久成人免费| 久久国产精品一区二区三区四区| 好久没做在线观看| 精品sm在线观看| 蜜臀久久99精品久久久久久| 欧美亚洲一区| 国产精品视频久久| 性做久久久久久久| 亚洲综合色区另类av| 日本精品一二三| 在线视频观看日韩| 久久国产欧美精品| 欧美日韩在线精品一区二区三区激情综合 | 91美女精品福利| 欧美成人精品欧美一级乱| 国产精品入口久久| 国产精品久久久久久久久久久久久久 | 理论电影国产精品| 亚洲最大的网站| 色视频在线观看福利| 日韩欧美在线第一页| 好吊视频在线观看| 亚洲婷婷在线| 国产精品色视频| 思思99re6国产在线播放| 3d动漫精品啪啪| 精品黑人一区二区三区观看时间| 欧美激情理论| 亚洲综合最新在线| 国产粉嫩一区二区三区在线观看| 欧美三级视频在线观看| 第四色在线视频| 一个色综合网| 国产精品极品尤物在线观看 | 伊人久久五月天| 国产又黄又爽视频| 亚洲成人激情综合网| 中文字幕线观看| 黑人一区二区三区四区五区| 欧美日韩在线一区二区三区| 丁香花在线电影| 亚洲美女av在线播放| 在线免费av片| 欧美激情在线看| 国内外成人激情视频| 日韩精品一区二区久久| 亚洲综合在线播放| 亚洲伦乱视频| 亚洲视频在线看| 日韩一区二区视频在线| 国产精品理论在线观看| 国产裸体视频网站| 午夜在线精品| 日本三日本三级少妇三级66| 亚洲精品进入| 国产日韩欧美综合| 欧美xxxx免费虐| 欧美影院午夜播放| 欧美日韩综合一区二区| 久久久美女毛片| 欧美日韩一区二区在线免费观看| 久久久国产精品| 蜜桃视频在线观看成人| 年轻的保姆91精品| 欧美黄色www| 尤物视频在线免费观看| 日韩第一页在线| 伊人手机在线视频| 久久久久久久久免费| 人妻激情偷乱视频一区二区三区| 久久精品中文| 免费在线观看视频a| 伊人情人综合网| 先锋影音网一区| 91精品国产一区二区在线观看 | 美女又爽又黄视频毛茸茸| 国产麻豆精品视频| 自拍偷拍一区二区三区四区| 色综合五月天| 欧洲成人一区二区| 亚洲涩涩av| 国产一区在线观| xxxxxhd亚洲人hd| 亚洲一区二区三区毛片| 日本一区二区中文字幕| 久久久精品2019中文字幕神马| 欧美日韩激情视频一区二区三区| 91福利在线观看| 99久久久免费精品| 中文在线免费一区三区高中清不卡 | √最新版天堂资源网在线| 精品视频9999| 动漫av一区二区三区| 天天色 色综合| 女人又爽又黄免费女仆| 99久久免费精品| 激情五月亚洲色图| 免费日韩一区二区| www.亚洲天堂网| 国产伦精品一区二区三区千人斩| 久久国产精品 国产精品| 首页亚洲中字| 欧美18视频| 欧美日韩在线网站| 91九色在线观看| 久久久91麻豆精品国产一区| 91中文字幕在线| 伊色综合久久之综合久久| 日韩免费不卡av| 日韩在线免费| 国产精品91在线| 亚洲电影有码| 国产在线精品自拍| 精品一区二区三区中文字幕在线| 97netav| 麻豆一区一区三区四区| 久久精品99久久| 国产麻豆一区二区三区精品视频| 日韩欧美视频一区二区| 色综合天天爱| av在线播放天堂| 91久久电影| 欧美日韩dvd| 99精品免费网| 国产a级黄色大片| 亚洲黄色精品| 午夜视频在线瓜伦| 美美哒免费高清在线观看视频一区二区 | 东热在线免费视频| 久久精品国产精品亚洲| 大黄网站在线观看| 日本a级片电影一区二区| 国产精品久久乐| 国产v亚洲v天堂无码| 免费短视频成人日韩| 天天干天天操天天干天天操| 影音先锋日韩资源| 亚洲精品白虎| 竹菊久久久久久久| 中文字幕免费在线不卡| 亚洲东热激情| 性欧美极品xxxx欧美一区二区| 国产一区二区精品在线观看| 人妻av一区二区| 国产精品911| 国产性生活一级片| 99免费精品在线观看| 自拍偷拍第9页| 久久久久久一二三区| 国产高潮流白浆| 欧美日韩在线第一页| 国产日韩一级片| 亚洲欧美色婷婷| 婷婷在线播放| 国产精品日韩在线播放| 狠狠一区二区三区| 欧美 国产 精品| 日韩福利电影在线观看| 在线精品视频播放| 中文字幕在线不卡| 精品国产欧美日韩不卡在线观看| 富二代精品短视频| 精品久久国产视频| 日韩欧美色综合| jizz亚洲| 2025国产精品视频| 欧美成人免费电影| 国产成人精品av| 久久悠悠精品综合网| 8x8ⅹ国产精品一区二区二区| 秋霞电影一区二区| 午夜精品久久久久久久99热影院| 久久精品99久久久| 免费污网站在线观看| 性做久久久久久| 国产黄色片网站| 亚洲福利视频网站| 三级无遮挡在线观看| 欧美国产日韩精品| 精品国产一区二区三区2021| 亚洲欧洲精品在线| 日本不卡一区二区三区 | 国产婷婷色一区二区三区四区| 亚洲国产综合久久| 精品国产1区二区| 天天干在线视频论坛| 91亚洲精品久久久| 果冻天美麻豆一区二区国产| 不卡中文字幕在线| 精品一区中文字幕| 国产传媒视频在线| 亚洲综合成人网| 国产偷拍一区二区| 久热爱精品视频线路一| 成人黄色91| 性做爰过程免费播放| 久久99精品久久只有精品| 国精产品视频一二二区| 欧美日韩视频专区在线播放| jizzjizz在线观看| 国产精品一区二区三区毛片淫片 | 美国一区二区三区在线播放| 奇米网一区二区| 欧美男男青年gay1069videost| 日本中文字幕在线播放| 91热福利电影| 欧美精品网站| 无码内射中文字幕岛国片| 久久久久高清精品| 一区二区视频免费观看| 亚洲第一天堂无码专区| 华人av在线| 牛人盗摄一区二区三区视频| 日韩福利电影在线| 欧美色图17p| 欧美一级在线视频| 欧美日韩色网| 久久综合九色99| 日本不卡123| 国产精品久久久久久久精| 欧美sm美女调教| 亚洲三级欧美| 成人av网站观看| 成久久久网站| 久久视频这里有精品| 久久综合视频网| 国产亚洲成人av| 91精品欧美久久久久久动漫| h片在线免费观看| 精品国产第一页| 国产精品草草| 狠狠人妻久久久久久综合蜜桃| 色婷婷精品久久二区二区蜜臀av | 亚洲成人精品视频| 韩国美女久久| 午夜在线视频免费观看| 99re66热这里只有精品3直播| 国产喷水在线观看| 精品久久五月天| 91大神在线观看线路一区| 国产欧美日韩视频一区二区三区| 国产精品亚洲综合久久| 日韩免费av一区| 亚洲精品国产精品国产自| 免费av不卡在线观看| 欧美日韩国产不卡在线看| 激情欧美日韩一区二区| 欧美一二三区视频|