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

推薦一個檢測 JavaScript 內存泄漏的神器

開發 架構
最近,Meta 開源了一款檢測 JavaScript 代碼內存泄漏的框架:MemLab,我們來一起看看這個框架有啥神奇之處吧。

大家好,我是 ConardLi?。作為一名 Web? 應用程序開發者,排查和修復 JavaScript 代碼的內存泄漏一直是最困擾我的問題之一。

最近,Meta? 開源了一款檢測 JavaScript? 代碼內存泄漏的框架:MemLab,我們來一起看看這個框架有啥神奇之處吧~

2020? 年,Meta? 的工程師將 Facebook.com? 重構為了單頁應用(SPA?),程序的大部分渲染和導航都會在客戶端使用 JavaScript? 完成。后來他們又使用類似的架構來重構了 Meta? 的大多數其他流行的網絡應用程序,包括 Instagram? 和 Workplace?。雖然這種架構能夠提供更快的用戶交互、更好的開發者體驗和更像原生應用程序的感覺,但是在客戶端維護 Web 應用的狀態會讓內存的管理變得更加復雜。

使用 Meta? 網站的用戶經常會快速注意到一些性能和功能正常使用的問題。然而,內存泄漏就是另一回事了。它不會立即被察覺出來,因為它一次會占用一大塊內存 — 然后逐漸影響整個 Web 會話并讓后續的交互和響應變得更慢。

Meta? 的工程師花費了大量時間來測試、優化和控制頁面加載和交互時間,以及 JavaScript? 的代碼大小。相比之下,他們在管理 Web? 瀏覽器內存方面做的工作并不多。當分析新 Facebook.com? 的內存使用情況時,發現客戶端的內存使用情況和內存不足 (OOM) 崩潰的數量一直在攀升。較高的內存使用對頁面加載、交互性能、用戶參與度等核心指標都有負面影響。

為了幫助開發者解決這個問題,Meta? 的工程師構建了 MemLab?,這是一個 JavaScript? 內存測試框架,可以自動進行內存泄漏檢測,并且更容易找到內存泄漏的根本原因。Meta? 使用 MemLab 成功地控制了不可持續的內存增長,并識別出了產品和基礎設施中的內存泄漏和內存優化的一些手段。

導致 Web 應用內存過高的原因

因為內存泄漏通常不是很明顯,在開發過程中,以及做 Code Review? 的時候都很難發現,而且在生產環境中通常也很難找到根本原因。雖然主流的 JavaScript 運行時都有垃圾回收機制,那么為什么還會有內存泄漏呢?

JavaScript 代碼中可能會有很多隱藏對象的引用,而隱藏的引用會以許多意想不到的方式導致內存泄漏。

例如:

var obj = {};
console.log(obj);
obj = null;

在 Chrome? 中,即使我們將引用設置為 null? ,這段代碼也會泄漏 obj? 。發生這種情況是因為 Chrome? 需要保留對打印對象的內部引用,以便以后可以在 Web 控制臺中對其進行檢查(即使在 Web 控制臺沒打開的情況下)。

在某些情況下,內存在技術上并沒有發生泄漏,而是在用戶會話期間線性增長而且沒有限制。最常見的原因是客戶端緩存沒有內置任何釋放的邏輯,無限滾動列表沒有任何虛擬化的功能,無法在添加新內容時從列表中刪除較早的內容。

我們也沒有適當的自動化系統和流程來控制內存,因此防止此類問題的唯一防御措施就是專家通過 Chrome DevTools 定期挖掘內存泄漏,一些大型的項目幾乎每天都會有發布和變更,這樣的工作方式是不可持續的。

MemLab 的工作原理

MemLab? 通過預定義的測試場景運行無頭瀏覽器并比較和分析 JavaScript 堆快照來發現內存泄漏的問題。

圖片

這個過程可以分為下面六個步驟:

1.「瀏覽器交互」:MemLab? 使用 Puppeteer 自動化瀏覽器,在目標頁面上查找泄露的對象;

2.「區分堆」:導航到一個頁面然后離開它,正常情況下該頁面分配的大部分內存也應該被釋放,如果沒有,可能暗示著存在內存泄漏。MemLab? 通過區分 JavaScript? 堆并記錄在頁面 B? 上分配的一組對象,這些對象沒有在頁面 ?A 上分配,但在重新加載頁面 A 時仍然存在,從而發現潛在的內存泄漏;

3.「細化內存泄漏列表」:內存泄漏檢測器進一步結合了特定框架的知識來細化泄漏對象的列表。例如,React? 分配的 Fiber? 節點(React? 用于渲染虛擬 DOM 的內部數據結構)應該在我們訪問多個選項卡后清理時釋放。

4.「生成 retainer traces」:遍歷堆并為每個泄漏的對象生成 retainer traces? 。trace? 顯示了泄漏對象為何以及如何在內存中保持活動狀態。打破引用鏈意味著泄漏的對象將不再可以從 GC? 的根訪問,因此可以進行垃圾回收。通過一步步地跟蹤,就可以找到應該設置為 null 的引用;

5.「聚合 retainer traces」:將所有 retainer traces? 聚集在一起,并為每個共享相似 retainer traces 的泄漏對象聚合顯示為一個跟蹤,其中還包括調試信息,例如支配節點和保留大小。

6.「報告泄漏」:定期運行 MemLab?,以持續收集 retainer traces?,任何新的 traces? 都會記錄到內部儀表板,開發者可以查看每個內存泄漏的 retainer traces 上的對象屬性。

MemLab 有哪些能力

內存泄漏檢測

對于瀏覽器內存泄漏的檢測,MemLab? 需要開發者提供的唯一輸入就是一個測試場景文件,這個文件定義了如何通過使用 Puppeteer API? 和 CSS? 選擇器覆蓋三個回調來與網頁交互。MemLab? 會自動區分 JavaScript 堆、優化內存泄漏并聚合結果。

圖片

JavaScript 堆的 Graph-view API

MemLab? 支持一個自定義的泄漏檢測器,作為篩選器回調,應用于每個由目標交互分配的泄漏候選對象,但之后從不釋放。泄漏過濾器回調函數可以遍歷堆并確定哪些對象是內存泄漏。例如,我們的內置檢漏器會跟蹤 React Fiber? 節點的返回鏈路,檢查 Fiber? 節點是否與 React Fiber 樹分離。

圖片

為了分析每個可能內存泄漏的上下文,MemLab? 提供了一個 JavaScript? 堆的內存效率圖。這可以在不了解 V8? 堆快照文件結構的任何領域知識的情況下查詢和遍歷 JavaScript 堆。

在視圖中,堆中的每個 JavaScript? 對象或原生對象都是一個圖節點,堆中的每個 JavaScript? 引用都是一個圖的邊。實際應用程序的堆大小通常很大,因此圖視圖需要在提供直觀的面向對象堆遍歷 API? 的同時提高內存效率。因此,圖節點被設計成了虛擬的,不通過 JavaScript? 引用進行連接。當分析代碼遍歷堆時,虛擬圖會部分地即時構建圖的接觸部分。圖的任何部分都可以很容易地釋放,因為這些虛擬節點彼此之間沒有 JavaScript 引用。

堆視圖可以從基于 Chromium? 的瀏覽器、Node.js、Electron? 和 Hermes? 獲取的 JavaScript? 堆快照加載。這允許分析復雜的模式并回答諸如 “有多少 React Fiber? 節點是備用的 Fiber 節點,它們用于不完整的并發渲染?”之類的問題。

import {getHeapFromFile} from '@memlab/heap-analysis';
const heapGraph = await getHeapFromFile(heapFile);
heapGraph.nodes.forEach(node => {
// heap node traversal
node.type
node.references
);

內存斷言

Node.js? 程序或 Jest? 測試也可以使用 graph-view API 來獲取其自身狀態的堆視圖,進行自內存檢查,并編寫各種內存斷言。

import type {IHeapSnapshot} from '@memlab/core';
import {config, takeNodeMinimalHeap, tagObject} from '@memlab/core';

test('memory test', async () => {
config.muteConsole = true;
const o1 = {};
let o2 = {};

// tag o1 with marker: "memlab-mark-1", does not modify o1 in any way
tagObject(o1, 'memlab-mark-1');
// tag o2 with marker: "memlab-mark-2", does not modify o2 in any way
tagObject(o2, 'memlab-mark-2');

o2 = null;

const heap: IHeapSnapshot = await takeNodeMinimalHeap();

// expect object with marker "memlab-mark-1" exists
expect(heap.hasObjectWithTag('memlab-mark-1')).toBe(true);

// expect object with marker "memlab-mark-2" can be GCed
expect(heap.hasObjectWithTag('memlab-mark-2')).toBe(false);

}, 30000);

內存工具箱

除了內存泄漏檢測,MemLab? 還包括一組內置的 CLI? 命令和 API,用于尋找可能的內存優化機會:

圖片圖片

Meta 使用 MemLab 的實踐

在過去的幾年中,Meta? 一直在使用 MemLab 檢測和診斷內存泄漏,并收集了很多有助于優化內存、減少 OOM 崩潰并改善用戶體驗的手段。

圖片

在 2021? 年上半年, Facebook.com? 上的 OOM? 崩潰減少了 50%。

React Fiber 節點清理

為了渲染組件,React? 構建了 Fiber? 樹 — 一個 React? 用于渲染虛擬 DOM? 的內部數據結構。雖然 Fiber? 樹看起來像一棵樹,但它是一個雙向圖,將所有 Fiber? 節點、React? 組件實例和關聯的 HTML DOM? 元素強連接起來。理想情況下,React? 維護對組件 Fiber? 樹的根的引用,并防止 Fiber? 樹被垃圾回收。當一個組件被卸載時,React 會斷開組件的根與 Fiber 樹的其余部分之間的連接,然后這些部分就可以被垃圾回收了。

擁有這樣的強連接圖的缺點是,如果有任何外部引用指向圖的任何部分,就無法對整個圖進行垃圾回收。例如,下面 export? 語句在模塊范圍級別緩存 React? 組件,因此相關的 Fiber? 樹和分離的 DOM 元素永遠不會被釋放。

export const Component = (( 
<List> ... </List>
): React.Element<typeof List>);

也不僅僅是 React 數據結構要 keep alive? ,Hooks? 和它們的閉包也可以讓各種其他對象保活。這意味著單個 React 組件泄漏可能會導致頁面對象的重要部分泄漏,從而導致巨大的內存泄漏。

圖片

為了防止 Fiber? 樹中內存泄漏的級聯效應,MemLab? 添加了一個樹的完整遍歷,當組件在 React 18? 中卸載時會進行清理。這可以讓垃圾回收器在清理未掛載的樹方面做得更好一點。這個優化將 Facebook? 上的平均內存使用量減少了近 25%?,其他使用 React? 的站點在升級時也有了很大的改進。你可能會擔心這種比較激進的清理方式可能會減慢 React 組件的卸載速度,但令人驚訝的是,由于內存的減少,性能也有顯著的提升。

string interning

通過利用 MemLab? 中的 heap analysis API,Meta? 團隊發現字符串占據了 70%? 的堆內存,其中一半的字符串至少有一個重復的實例。(V8? 對 string interning 支持的不是很好,這是一種對具有相同值的字符串實例進行重復數據刪除的優化。)

另外很大一部分字符串內存被 Relay? 中緩存的鍵字符串消耗。通過與 Relay? 和 React Apps? 團隊合作,可以在客戶端插入和縮短過長的字符串鍵來優化 Relay 緩存鍵字符串。

這種優化使 Relay? 能夠緩存更多數據,允許站點向用戶顯示更多內容,尤其是在客戶端 RAM? 有限的情況下。內存 p99? 和 OOM? 崩潰減少了 20%,頁面渲染速度更快,用戶體驗得到改善,在收入上也有一定提升。

試用 MemLab:

npm i -g memlab

最后:MemLab Github:https://github.com/facebookincubator/memlab

責任編輯:趙寧寧 來源: code秘密花園
相關推薦

2025-08-27 08:24:23

2025-08-27 00:01:55

2023-05-14 23:38:43

Glarity用戶視頻

2020-10-23 10:50:39

內存泄漏語言代碼

2011-06-16 09:28:02

C++內存泄漏

2009-06-16 11:20:22

內存泄漏

2021-08-05 15:28:22

JS內存泄漏

2020-06-08 09:18:59

JavaScript開發技術

2025-04-11 08:20:00

NetQuality網絡質量檢測網絡性能

2023-10-31 16:40:38

LeakCanary內存泄漏

2018-12-07 10:52:08

內存泄漏方法

2015-07-10 09:15:47

LeakCanary內存泄漏

2010-09-25 11:07:45

Java內存泄漏

2022-05-26 09:51:50

JavaScrip內存泄漏

2009-06-10 22:03:40

JavaScript內IE內存泄漏

2022-05-27 09:02:31

Openbase開源前端

2025-07-26 00:00:00

AI驅動工具

2025-08-04 01:00:00

JavaScript內存泄漏前端

2025-07-09 03:00:00

2023-11-22 08:26:03

HutoolJava工具集
點贊
收藏

51CTO技術棧公眾號

99热都是精品| 国产精品综合网站| 国产亚洲无码精品| www.久久.com| 一区二区三区在线免费播放| 国严精品久久久久久亚洲影视| 免费看毛片网站| 忘忧草精品久久久久久久高清| 精品久久人人做人人爰| 毛片一区二区三区四区| 黄色网页在线播放| 久久蜜桃av一区二区天堂| 成人精品视频在线| 久久精品视频7| 在线看片不卡| 亚洲香蕉成视频在线观看| 日本黄色三级网站| 制服丝袜专区在线| 亚洲一区二区精品久久av| 亚洲7777| 日韩欧美在线番号| 国产成人超碰人人澡人人澡| 国产精品成人一区二区| 久久久久久久福利| 小处雏高清一区二区三区| 日韩精品中文字幕久久臀| 特种兵之深入敌后| 欧美少妇激情| 色哟哟精品一区| 91九色丨porny丨国产jk| 美女黄视频在线观看| 国产视频一区在线观看| 精品一区二区三区视频日产| 国产视频一区二区三区四区五区| 日本欧美久久久久免费播放网| 午夜精品99久久免费| 欧美成人精品欧美一级| 久久福利综合| 国产一区二区三区在线免费观看 | 欧美久久久久久久久| 91av资源网| 波多野结衣中文字幕久久| 亚洲美女淫视频| 在线免费一区| av国产在线观看| 国产午夜精品一区二区三区四区| 国产综合精品一区二区三区| 丰满人妻av一区二区三区| 久久国产麻豆精品| 国产精品视频区| 日韩黄色一级视频| 三级久久三级久久| 国产成人亚洲综合| 五月婷婷视频在线| 亚洲在线日韩| 日韩av免费在线播放| 久久精品国产成人av| 中文亚洲免费| 91sa在线看| 国产婷婷色一区二区在线观看| 国产日韩一区二区三区在线播放| 午夜精品三级视频福利| 日韩av在线播放观看| 在线免费av资源| 一区二区三区成人在线视频| 中文字幕乱码免费| 在线看一级片| 亚洲专区一二三| 97视频久久久| 看黄在线观看| 91福利社在线观看| 黄色一级一级片| 韩日一区二区| 欧美一区二区三区四区久久| 日本特黄在线观看| 97人人澡人人爽91综合色| 精品人伦一区二区色婷婷| 91传媒理伦片在线观看| 牛牛影视久久网| 亚洲欧美在线第一页| 性猛交娇小69hd| 999国产精品视频| 久精品免费视频| 国产一级特黄aaa大片| 国产精品毛片在线| 国产日韩欧美在线视频观看| av av片在线看| av成人动漫在线观看| 色姑娘综合av| 香蕉成人app免费看片| 亚洲成人免费视频| 中文字幕第80页| 日韩欧美激情电影| 亚洲精品视频在线观看视频| av在线播放中文字幕| 欧美精品观看| 国产成人+综合亚洲+天堂| 国产精品免费无遮挡| 成人毛片在线观看| 五月天亚洲综合情| av日韩国产| 欧美亚洲日本一区| 国产精品一区二区无码对白| 波多野结衣在线播放一区| 欧美黑人性猛交| 国产在线观看第一页| 高清不卡一区二区在线| 日本高清久久一区二区三区| 亚洲精品一线| 欧美午夜理伦三级在线观看| 日本精品一二三区| 99免费精品| 欧洲成人在线观看| 亚洲精品18在线观看| 欧美国产日韩亚洲一区| 国产手机免费视频| 国产精品欧美一区二区三区不卡| 亚洲男人天堂手机在线| 91视频免费在线看| 美女尤物国产一区| 久久久久无码国产精品一区| 污网站在线免费看| 欧美日韩视频专区在线播放| 亚洲欧美日本一区| 国产综合精品| 91精品视频在线免费观看| 黄色软件在线观看| 欧美日韩免费区域视频在线观看| 色哟哟免费视频| 天天射天天综合网| 国产在线高清精品| 成人在线观看一区| 色呦呦日韩精品| 久久精品综合视频| 一二三区精品| 国产偷久久久精品专区| av片在线观看网站| 欧美日韩国产高清一区二区三区 | 国产精品久久久久久久久久久久久久久久 | 午夜免费在线观看精品视频| 国产精品爽爽久久久久久| 国产精品毛片久久久久久| 国产精品亚洲a| 欧美男人操女人视频| 久久人91精品久久久久久不卡| 国产av无码专区亚洲av| 亚洲品质自拍视频| 91视频福利网| 欧美色一级片| 99蜜桃在线观看免费视频网站| 成人国产免费电影| 欧美一区二区视频在线观看 | 国产成人在线一区| 国产精品麻豆一区二区三区 | 不卡av免费在线| 精品欧美久久| 国产精品久久久久久久久| 国产露出视频在线观看| 欧美日韩另类一区| 成人免费精品动漫网站| 国产精品一区在线| 国产在线xxxx| 精品网站aaa| 国产91精品久久久久久久| 视频二区在线| 欧美优质美女网站| 男人在线观看视频| 成人动漫精品一区二区| av天堂永久资源网| 成人黄色av| 91亚洲精品视频| 3344国产永久在线观看视频| 精品视频在线播放免| 久久影视中文字幕| 日韩美女视频19| 国产乱淫av片| 久久久精品性| 在线视频不卡一区二区| 日韩一二三区| 欧美一区二区影院| 性开放的欧美大片| 91精品蜜臀在线一区尤物| 国产网址在线观看| 国产三级一区二区| 免费人成视频在线播放| 亚洲国内精品| 视频一区在线免费观看| 精品国产第一国产综合精品| 国内精久久久久久久久久人| 懂色av中文在线| 欧美一区二区不卡视频| 毛片在线免费视频| 日韩一区欧美一区| 内射中出日韩无国产剧情| 美女mm1313爽爽久久久蜜臀| 白白操在线视频| 国产成人影院| 99久热re在线精品视频| 影音成人av| 久久青草福利网站| 国产视频中文字幕在线观看| 亚洲国产天堂久久综合| 一卡二卡在线观看| 一本色道**综合亚洲精品蜜桃冫| 91麻豆精品成人一区二区| 26uuu国产日韩综合| 一级片免费在线观看视频| 欧美亚洲一区二区三区| 草草草视频在线观看| 欧美日韩一区二区综合| 极品校花啪啪激情久久| 91成人在线网站| 国产成人高清激情视频在线观看| av片在线观看网站| 色婷婷成人综合| 青青久在线视频| 欧美大胆人体bbbb| 97精品人妻一区二区三区在线| 婷婷国产在线综合| 日本妇女毛茸茸| 国产精品久久久爽爽爽麻豆色哟哟 | 精品香蕉一区二区三区| 国产黄色片免费观看| 欧美日韩一区二区三区在线看| 日本va欧美va国产激情| 一区二区三区中文字幕电影| 美国一级黄色录像| 久久久久久久精| 欧美无人区码suv| 国产成人免费视频网站高清观看视频| 亚洲免费一级视频| 日韩高清不卡一区二区| 国内外成人激情视频| 红桃视频国产一区| 国产免费内射又粗又爽密桃视频| 色喇叭免费久久综合网| 手机在线观看国产精品| 九九久久婷婷| 免费日韩av电影| 先锋影音国产精品| 免费看污久久久| 欧美男男gaytwinkfreevideos| 精品国产乱码久久久久久郑州公司 | 人妻 日韩 欧美 综合 制服| 国产精品99精品久久免费| 欧美国产日韩另类| 国产综合色视频| 亚洲精品在线视频播放| 精品伊人久久久久7777人| 中文字幕第100页| 久久99精品国产.久久久久久| 在线免费观看av的网站| 日本不卡的三区四区五区| 日本久久精品一区二区| 蜜臀99久久精品久久久久久软件| 爱情岛论坛成人| 久久精品国产99久久6| 亚洲精品综合在线观看| 久久国产三级精品| 在线播放黄色av| 国产成人免费高清| 超碰97在线资源站| 久久这里只有精品6| 亚洲av无码一区二区三区人| 国产欧美日韩久久| 日本在线一级片| 一个色综合av| 香蕉免费毛片视频| 91搞黄在线观看| 888奇米影视| 精品奇米国产一区二区三区| 性xxxx18| 色悠悠久久久久| 性欧美videoshd高清| 亚州av一区二区| 在线成人视屏| 成人自拍性视频| 国产精品videossex| 欧美动漫一区二区| 希岛爱理一区二区三区| 欧美激情亚洲天堂| 乡村艳史在线观看| 亚洲精品美腿丝袜| www深夜成人a√在线| 亚洲在线视频网站| 好吊色在线视频| 91精品国产乱码| 日韩av成人| 久久久999国产精品| 国产精品原创| 国产日韩中文字幕| 加勒比色老久久爱综合网| 四虎一区二区| 亚洲网站视频| 密臀av一区二区三区| 国产一区在线观看视频| jlzzjizz在线播放观看| 国产精品国产三级国产普通话99| 久久久久亚洲天堂| 91高清在线观看| 日本韩国在线观看| 久久久国产精品视频| 忘忧草在线影院两性视频| 成人在线激情视频| 欧美极品中文字幕| 日本aa在线观看| 精品一区二区在线看| 国产伦精品一区二区三区妓女| 成人免费一区二区三区视频| 天堂网一区二区三区| 日韩一区二区三区电影| 国产特黄在线| 91黑丝在线观看| 亚洲高清在线一区| 影音先锋欧美资源| 视频一区二区三区入口| 捆绑裸体绳奴bdsm亚洲| 亚洲日本在线看| 中文字幕在线网址| 亚洲欧美日韩精品久久奇米色影视 | jizz一区二区| 欧美一区二区三区爽爽爽| 在线观看视频一区二区 | 成人蜜臀av电影| 国产一区二区三区在线视频观看| 91成人免费电影| 手机看片福利在线观看| 国内揄拍国内精品少妇国语| 老司机亚洲精品一区二区| 亚洲精美视频| 久久久久久网| 欧美狂猛xxxxx乱大交3| 精品国产91久久久久久| 人人妻人人玩人人澡人人爽| 久色乳综合思思在线视频| 欧美视频精品| 一本久道久久综合| 蜜臀av一区二区三区| 精品国产aaa| 欧美专区在线观看一区| 黄色av网站在线| 国产不卡视频在线| 九九久久电影| 国产精品美女视频网站| 一卡二卡三卡在线观看| 亚洲乱码国产乱码精品精天堂| 678在线观看视频| 精品国产一区二区三| 国产精品一二| wwwwww日本| 91精品办公室少妇高潮对白| 国产在线91| 国产久一一精品| 国产精品久久久久一区二区三区厕所| 污污网站免费看| 1000部国产精品成人观看| 国产精品久久久久久久一区二区| 不卡av电影院| 日韩有吗在线观看| 成年女人18级毛片毛片免费| 成人午夜视频在线| 一本一道无码中文字幕精品热| 亚洲欧洲美洲在线综合| 桃子视频成人app| 亚洲在线色站| 国产精品99久久久久久久vr| 国产中文字字幕乱码无限| 亚洲激情在线视频| 在线成人视屏| 久久久成人精品一区二区三区| 国产精品一区二区你懂的| 久草免费在线观看视频| 日韩经典一区二区三区| 欧美黑人一区| 2025韩国大尺度电影| 高清不卡在线观看av| 7799精品视频天天看| 最近2019免费中文字幕视频三| 在线观看亚洲精品福利片| 99久久久精品视频| 91丨porny丨户外露出| 亚洲网站在线免费观看| 欧美成人免费在线观看| 欧美色资源站| 亚洲xxx在线观看| 亚洲一卡二卡三卡四卡无卡久久 | 中文字幕亚洲自拍| 亚洲国产一区二区三区网站| 久久久久久久久久久视频| 中文字幕欧美三区| 免费看黄色一级视频| 日本久久久久久久| 欧美日韩岛国| 在线不卡av电影| 欧美成人一级视频| 岛国一区二区| 国产精品自拍片| 亚洲摸摸操操av| 精品av中文字幕在线毛片| 亚洲综合中文字幕在线|