日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Hades:移动端静态分析框架

發(fā)布時間:2024/7/5 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Hades:移动端静态分析框架 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

只有通過別人的眼睛,才能真正地了解自己 ——《云圖》

背景

作為全球最大的互聯(lián)網(wǎng) + 生活服務(wù)平臺,美團點評近年來在業(yè)務(wù)上取得了飛速的發(fā)展。為支持業(yè)務(wù)的快速發(fā)展,移動研發(fā)團隊規(guī)模也逐漸從零星的小作坊式運營,演變?yōu)榍思壯邪l(fā)軍團協(xié)同作戰(zhàn)。

在公司蓬勃發(fā)展的大背景下,移動項目架構(gòu)也有了全新的演進方向:需要支持高效的集成策略,支持研發(fā)流程自動化等等,最終提升研發(fā)效能,加速產(chǎn)品迭代和交付能力。

雖然高效的研發(fā)交付體系幫助 App 項目縮短了迭代周期,但井噴式的模塊發(fā)版和頻繁的項目集成,使得純?nèi)斯さ捻椖烤S護和質(zhì)量保證變得“獨木難支”。

上圖漫畫中,列舉了大型項目在持續(xù)優(yōu)化和維護過程中較為常見的幾類需求。這些需求主要包括以下幾個方面:

  • 在 CI 流程中加入靜態(tài)準入檢查,避免繁瑣的人工 Review 以及減少人工 Review 可能帶來的失誤。
  • 為了推進項目的優(yōu)化過程,需要方法數(shù)監(jiān)控、宏定義分析等代碼分析報表和監(jiān)控。
  • 零 PV 報表、依賴分析和頭文件引用規(guī)范、無用代碼分析等項目優(yōu)化方案。
  • 不難發(fā)現(xiàn),這些需求的本質(zhì)是:借助代碼靜態(tài)分析能力,提升項目可持續(xù)發(fā)展所需要的自動化水平。針對 C/Objective-C 主流的靜態(tài)分析開源項目包括:Static Analyzer、Infer、OCLint 等。但是,這些分析工具對我們而言存在一些問題:

    • 開發(fā)成本高,收益有限,研發(fā)參與積極性不夠。
    • 針對局部代碼分析,跨編譯單元以及全局性分析較難。
    • 增量分析困難,CI 靜態(tài)檢查效率低下。
    • 工具性較強,大部分只作代碼規(guī)范檢查,應(yīng)用范疇局限。
    • 接入和維護成本高,難以平臺化。

    針對以上背景和現(xiàn)有方案的不足,我們決定自研基于語義的靜態(tài)分析框架。

    Hades 項目簡介

    大眾點評靜態(tài)分析框架 Hades,取名源于古希臘神話中的冥王。冥王 Hades 公正無私,能夠?qū)徱曥`魂的是非善惡。

    Hades 框架支持語義分析能力,我們希望這種能力不僅僅能夠去實現(xiàn)一個傳統(tǒng)的 Lint 工具,而且能成為創(chuàng)造更多能力的基礎(chǔ),可以幫助我們更輕松地審視代碼,理解把控大型項目。

    Hades 方案選型

    文本處理方式

    首先,最簡單的靜態(tài)分析是字符匹配和文本處理。這種方式雖然實現(xiàn)簡單,但是存在能力上限,也不可能在語義理解上有足夠的把控力。另外,以正則匹配為核心建立的工具棧難以得到持續(xù)優(yōu)化。為了分析項目的依賴關(guān)系,我們需要判斷代碼中的符號含義以及符號間關(guān)系(如包含哪些類,類中有哪些方法等),分析過程的正則表達式如下圖所示。

    由此可見,繁瑣的文本匹配不僅可讀性差,也存在容易分析出錯的問題。

    基于編譯器的靜態(tài)分析方案

    我們需求的本質(zhì)是對代碼進行分析,而在源代碼編譯過程中,語法分析器會創(chuàng)建出抽象語法樹(Abstract Syntax Tree 縮寫為 AST)。AST 是源代碼的抽象語法結(jié)構(gòu)的樹狀表現(xiàn)形式,樹上的每個節(jié)點都表示源碼的一種結(jié)構(gòu)。

    以上圖為例,代碼塊區(qū)域是用 Objective-C 和 TypeScript 編寫的一個簡單條件語句源碼,下面是其對應(yīng)的抽象語法結(jié)構(gòu)表達。這種樹狀的結(jié)構(gòu)表達,省略了一些細節(jié)(比如:沒有生成括號節(jié)點),從圖中的這種映射關(guān)系中我們也可以發(fā)現(xiàn):

    • 源碼的語法結(jié)構(gòu)是可以通過明確的數(shù)據(jù)結(jié)構(gòu)表示的。
    • 大多數(shù)編程語言都可以用相似的 AST 表達的。

    對于 C/Objective-C 而言,主流編譯器是 Clang/LLVM(Low Level Virtual Machine)的,它是一個開源的編譯器架構(gòu),并被成功應(yīng)用到多個應(yīng)用領(lǐng)域。Clang(發(fā)音為/kl??/,不是C浪)是 LLVM的一個編譯器前端,它目前支持 C, C++, Objective-C 等編程語言。Clang 會對源程序進行詞法分析和語義分析,將分析結(jié)果轉(zhuǎn)換為 AST。現(xiàn)有方案中不少 Lint 工具便是基于 Clang 的,Clang 包含了以下特點:

    • 編譯速度快:Clang 的編譯速度遠快于 GCC。
    • 占用內(nèi)存小:Clang 生成的 AST 所占用的內(nèi)存是 GCC 的五分之一左右。
    • 模塊化設(shè)計:Clang 采用基于庫的模塊化設(shè)計,易于 IDE 集成及其他用途的重用。

    因此,借助 Clang 的模塊化設(shè)計和高效編譯等諸多優(yōu)點,Hades 也將更容易開發(fā)和升級維護。Clang 對源碼強有力的分析能力也是主流靜態(tài)分析工具的不二之選。

    Clang AST 初識

    Clang 項目非常龐大。僅僅是 Clang AST 相關(guān)代碼就超過 10W+ 行代碼。如何利用 Clang 實現(xiàn) AST 分析工作,這里可以參考官網(wǎng)提供的文檔 Choosing the Right Interface for Your Application ,以下是三種方式:

    • LibClang

      提供 C 語言的穩(wěn)定接口,支持Python Binding。AST 并不完整,不能完全掌控 Clang AST。

    • Clang Plugins

      提供 C++ 接口,更新快,不能保留上下文信息。插件的存在形式是一個動態(tài)鏈接庫,不能在構(gòu)建環(huán)境外獨立存在。

    • LibTooling

      提供 C++ 接口,更新快,可以通過標準的 main() 函數(shù)作為入口,可獨立運行,能夠完全掌控 AST,相比 Plugin 更容易設(shè)置。

    這里我們選擇可獨立運行并且能完全掌控 AST 的 LibTooling 作為 Hades 的基礎(chǔ)。

    在使用 Clang 的學習過程中,基本的概念便是表示 AST 的節(jié)點類型,這里重要的幾點是:

    • ASTContext。

    ASTContext 是編譯實例用來保存 AST 相關(guān)信息的一種結(jié)構(gòu),也包含了編譯期間的符號表。我們可以通過 TranslationUnitDecl * getTranslationUnitDecl(): 方法得到整個翻譯單元的 AST 的入口節(jié)點。

    • 節(jié)點類型。

    AST 通過三組核心類構(gòu)建:Decl (declarations)、Stmt (statements)、Type (types)。其它節(jié)點類型并不會從公共基類繼承,因此,沒有用于訪問樹中所有節(jié)點的通用接口。

    • 遍歷方式。

    為了分析 AST,我們需要遍歷語法樹。Clang 提供了兩種方式:RecursiveASTVisitor 和 ASTMatcher。RecursiveASTVisitor 能夠讓我們以深度優(yōu)先的方式遍歷 Clang AST 節(jié)點。我們可以通過擴展類并實現(xiàn)所需的 VisitXXX 方法來訪問特定節(jié)點。

    ASTMatcher API 提供了一種域特定語言(DSL)來構(gòu)建基于 Clang AST 的謂詞,它能高效地匹配到我們感興趣的節(jié)點。

    除了這兩種方式外,LibClang 也提供了 Cursors 來遍歷 AST。更多細節(jié)內(nèi)容可以前往 :clang.llvm.org 。

    常用開源工具的不足

    通過上一章節(jié)的介紹,我們大致了解了 Clang 的基本特點。 但是在實踐開發(fā)過程中發(fā)現(xiàn):通過 Clang API 去遍歷和分析 AST 的源碼樹形結(jié)構(gòu)較為復(fù)雜。現(xiàn)有靜態(tài)分析方案(如:OCLint),大多是直接給出封裝好的 Lint 工具,擴展方面也是提供腳手架生成 Rule 文件,然后在 Rule 中編寫訪問特定 AST 節(jié)點的方法(例如:VisitObjCMethodDecl 方法用來訪問 Objective-C 的方法定義)。

    因此,現(xiàn)有方案大多數(shù)只提供了直接訪問 AST 的方式,而且這種方式較為“局部”。每實現(xiàn)一個實際需求需要耗費大量精力去理解如何從 AST 分析映射到源碼的語義邏輯。

    但是,Code Review 時我們并不會將目標代碼轉(zhuǎn)換為 AST 然后再去分析代碼的語義如何,更多的是直接理解代碼的具體邏輯和調(diào)用關(guān)系。AST 樹狀結(jié)構(gòu)分析的復(fù)雜性容易帶來理解上的差異鴻溝。因此,這也不利于調(diào)動業(yè)務(wù)研發(fā)團隊的積極性,很多基于源碼分析工作也難以落地。

    Hades 核心實現(xiàn)

    為了讓分析過程更清晰,我們需要在 AST 的基礎(chǔ)之上再進行一次抽象。本章節(jié)主要內(nèi)容包含:Hades 的整體架構(gòu)、為什么要定義語義模型、定義什么樣的語義模型、如何輸出語義模型以及模型的序列化和持久化。

    Hades 總體架構(gòu)

    按照 Hades 的架構(gòu)目標進行基礎(chǔ)方案選型以后,我們來看下 Hades 的整體技術(shù)框架,可以用下圖所示的四層架構(gòu)表示:

    下面簡述下這幾層的不同職責:

    編譯器架構(gòu)層。Clang 的諸多優(yōu)勢前文已經(jīng)提到,這也是 Hades 的基礎(chǔ)依賴。

    Hades 核心層。在編譯器架構(gòu)層,我們借助 Clang 得到了代碼的抽象語法結(jié)構(gòu)表示 AST。而 Hades 核心層的職責便是將 AST 解析成人們更容易理解的,更高層級的語義模型。

    Hades 接口封裝層。抽象出的模型,能夠像 Clang 提供豐富 AST 訪問接口那樣,為開發(fā)者提供豐富的模型訪問接口。

    靜態(tài)分析應(yīng)用。通過 Hades 接口封裝,我們無需清楚底層模型是如何生成的,在這一層我們可以制作 Lint 或者其它監(jiān)控、分析工具。

    為什么 Hades 的架構(gòu)設(shè)計是這樣的呢?下面我們將一一道來。

    為何要定義語義模型 ?

    首先,正如「常用開源工具的不足」章節(jié)所述,大多現(xiàn)有方案是直接通過編譯器前端提供的接口實現(xiàn)對 AST 的操作,從而達到靜態(tài)分析的目的。

    當然,除了現(xiàn)有方案的不足以外,在業(yè)務(wù)研發(fā)過程中出現(xiàn)的 Case ,其原因大多數(shù)并不是違反了現(xiàn)有的 Lint 工具中所定義的基本語法規(guī)范,這些規(guī)則分析的往往是“常識”類問題。在靜態(tài)分析中,更多的是對象的錯誤方法調(diào)用和非法的繼承/復(fù)寫關(guān)系等問題,即便具備良好的編碼規(guī)范也會疏忽。這里乍一看沒太大區(qū)別,但是從著重點來說,Hades 的設(shè)計理念上會存在本質(zhì)區(qū)別。

    如上圖所示,現(xiàn)有方案如 OCLint 或者 Clang Static Analyser 等,其核心原理是在編譯器將源碼生成 AST 時,通過分析節(jié)點和節(jié)點間的關(guān)系,從而達到靜態(tài)分析的目的。這種方式不利于跨編譯單元分析,自然對項目級別的理解分析存在局限性。

    所以,這里可以借助 AST 針對每個編譯單元建立更直觀的、更容易理解的結(jié)構(gòu)化表達。我們將這個更高層級的語義表達稱為 HadesModel。

    定義什么樣的語義模型 ?

    建立 HadesModel 以后的靜態(tài)分析中,我們的著重點變化如下圖所示:

    下面我們可以簡單描述需要設(shè)計的 HadesModel 的基本特點:

    • HadesModel 可以結(jié)構(gòu)化表達源碼的語義。它能夠表達一個編譯單元定義了哪些接口聲明、實現(xiàn)了哪些類/類別的方法、定義和展開了哪些宏定義、對象的方法調(diào)用和函數(shù)使用情況等等。
    • HadesModel 使我們不需要了解 Clang 編譯器以及 AST 如何表達源碼。
    • HadesModel 以一個完整的編譯單元為單位,支持 JSON 格式表達。
    • 對于 Objective-C ,分析過程不必強依賴于 xcodebuild 編譯構(gòu)建過程。

    通過以上幾點特征描述,我們得到了 HadesModel 更清晰的表述:

    HadesModel 是基于 AST 的更高層級語義表達,它能夠序列化為 JSON 格式并描述完整的編譯單元,這種結(jié)構(gòu)化信息使得靜態(tài)分析能更接近于開發(fā)者閱讀理解源碼的思維習慣。

    在介紹完 HadesModel 的基本目標后,我們用下面一段簡單的 Objective-C 代碼為例來明確 HadesModel 的具體表達形式:

    在示例代碼中,我們簡單了解下包含的語義邏輯:

    • 這是一段 Objective-C 代碼,實現(xiàn)文件名為 HadesViewController.m。
    • 在實現(xiàn)文件中,定義了一個名為 HadesMacro 的宏定義。
    • 實現(xiàn)文件中包含了 HadesViewController 類的實現(xiàn)部分,HadesViewController 是 UIViewController 的子類。
    • HadesViewController 類中包含了兩個方法實現(xiàn)。其中第一個方法名為 sayHello ,里面包含了局部對象 testView 的初始化以及對象的方法調(diào)用,另外還包含了宏定義的使用。

    可以發(fā)現(xiàn),HadesModel 能夠表達開發(fā)者對語義信息的直觀理解即可。

    如何生成語義模型:HadesModel ?

    接下來介紹 Hades 基本架構(gòu)圖中 HadesCore 的核心實現(xiàn),重點在如何生成前文所述的 HadesModel。

    這里 HadesCore 借助 Clang LibTooling 分析源碼的 AST,然后將我們所需的語義信息抽象成 HadesModel。將數(shù)據(jù)抽象和轉(zhuǎn)換過程用以下簡要流程表示:

    下面將從一個流程圖來看看 HadesCore 是如何生成 HadesModel 的實現(xiàn)細節(jié):

    流程圖中主要包括以下幾點內(nèi)容。

    1. 構(gòu)建編譯數(shù)據(jù)庫

    首先,Hades 是基于 Clang 的模塊化設(shè)計開發(fā),所以它可以獨立運行,因此,可以利用 RubyGem 的方式將模型生成過程封裝并提供命令行工具。對于需要得到 HadesModel 的編譯單元.m,首先需要作為源文件集成到 workspace (iOS 可以用 CocoaPods),然后利用 Xcode 提供的 xcodebuild 結(jié)合 xcpretty 編譯得到項目的編譯數(shù)據(jù)庫 compile_commands.json。編譯數(shù)據(jù)庫用來指定每個編譯單元的命令行參數(shù)。

    2. 創(chuàng)建 HadesDriver

    在創(chuàng)建驅(qū)動器之前,可以使用 Clang 提供的 CommonOptionsParser 類,它將負責解析與編譯數(shù)據(jù)庫和輸入相關(guān)的命令行參數(shù),然后將其作為驅(qū)動器的輸入。驅(qū)動器控制整個模型生成周期,它的輸出結(jié)果便是 HadesModel。

    3. 構(gòu)建 HadesModel

    在 HadesDriver 的驅(qū)動下,首先需要創(chuàng)建編譯器實例,執(zhí)行編譯前可以分析宏定義和頭文件展開等預(yù)處理信息,并將這些內(nèi)容初始化到 HadesModel 對象。接著,在編譯器實例中將 FrontendAction 接口作為擴展編譯過程的執(zhí)行入口,利用 Clang LibTooling 提供的 ASTVistor 訪問 AST 節(jié)點(更多 Clang 技術(shù)細節(jié)見:Clang 8 documentation),最終將所有翻譯單元的“元數(shù)據(jù)”填充到 HadesModel。

    以前文的 HadesViewController.m 為例,我們得到 HadesModel 并序列化為 JSON 數(shù)據(jù)以后,如下圖所示:

    顯然,示例 HadesModel 已經(jīng)能夠表達開發(fā)者 Code Review 時,絕大多數(shù)“直白”的語義信息了。

    HadesModel 的序列化/持久化

    由于 HadesModel 最終需要以 JSON 格式作為提供靜態(tài)分析的原始數(shù)據(jù)類型,所以需要保證 HadesModel 具備序列化的能力。

    JSON 格式使 Hades 具備了全局分析能力,也符合設(shè)計之初的分析和平臺、語言無關(guān)的要求。再者,JSON 類型也方便利用具備較好類型系統(tǒng)的語言作為分析接口層。

    實踐中,以 iOS 常用的 CocoaPods 的 Pod 為單位,在私有 Pod 發(fā)版時生成模型數(shù)據(jù)然后打包存儲在 Maven 中,以便于增量分析

    在 CI 系統(tǒng)中,特別是大型項目持久化的模型存儲非常重要。CI 中為了加快集成速度,不得不使用部分二進制的集成方式,但是這樣將無法對靜態(tài)庫進行源碼分析。利用 Hades 的模型緩存,我們可以解決二進制集成的局限性。緩存數(shù)據(jù)也不需要再次編譯、模型生成等耗時操作,所以接入 Hades 后基本不影響集成項目的集成速度。

    Hades 應(yīng)用案例(1):制作 Lint 工具

    在這一章,我們將介紹 Hades 架構(gòu)中的接口層,以及在 Lint 工具上的應(yīng)用。

    HadesLint 架構(gòu)描述

    HadesLint 是基于 Hades 框架制作的靜態(tài)分析工具。作為平臺標準的 Lint 工具,目前在持續(xù)集成有了廣泛應(yīng)用(詳情見此篇文章:MCI:大眾點評千人移動研發(fā)團隊怎樣做持續(xù)集成?)。

    HadesLint 開發(fā)語言是 TypeScript。它具備完善的類型系統(tǒng),結(jié)合 VSCode 的智能補全和完善的 Debug 能力,使得 HadesLint 具備良好的開發(fā)體驗。

    HadesLint 的實現(xiàn)細節(jié)如下圖所示:

    在接入 HadesLint 的項目后,我們將項目以 Pod 為單位,從 Maven 中讀取緩存模型 Zip 包。如果不存在緩存,那么將利用前文所述封裝好的 HadesGem 通過編譯數(shù)據(jù)庫實時生成每個編譯單元的 HadesModel。

    由于我們的項目較大,模型數(shù)據(jù)量也非常龐大,為了防止分析過程內(nèi)存泄露的危險,提升分析性能,可以通過Lazy.js進行惰性求值,漸進加載有效解決了模型數(shù)據(jù)龐大的問題。

    被 Lazy.js 加載的 JSON 對象,需要通過 TypeScript 聲明來保證 HadesModel 具備類型。這樣,我們就可以在 VSCode 中編寫代碼時,享受自動補全、類型推斷,從而保證編寫過程更加安全、高效。借助 VSCode 對 TypeScript 的良好支持,在編寫分析過程中方便地 Debug。

    最后 HadesLint Driver 會加載每個規(guī)則對象,在規(guī)則中分析 HadesModel 然后確定檢查項是否合法。

    當然,如果希望程序執(zhí)行效率更高些,也可以嘗試 OCaml+ATD 來構(gòu)建 Lint 項目。

    HadesLint 應(yīng)用案例:打印項目中的類名

    需求描述:我們需要找到項目中定義的所有類名。

    我們只需要通過腳手架創(chuàng)建新的規(guī)則,然后編寫以下代碼(HadesLint規(guī)則代碼):

    this.hadesModels.each((hadesModel: HadesModel.HModel) => {hadesModel.class_list.forEach((occlass: HadesNode.Class) => {console.log(occlass.name);}) });

    編寫代碼以后,可以在 VSCode 的 Debug 面板中開啟調(diào)試:

    當然,除了以上簡單的查詢功能以外,我們也可以定制相對復(fù)雜的檢查規(guī)則,比如繼承鏈管控、方法復(fù)寫檢查、非空檢查等。

    在引出方法復(fù)寫管控之前,開發(fā)者往往會通過隨意繼承的方式復(fù)寫代碼,或者通過不合理擴展方式來滿足當前需求。但是,人工 Review 代碼很難保證集成項目中,這些擴展或者子類在運行時的行為。因此,對繼承鏈管控的需求非常有必要。我們的 App 之前就出現(xiàn)了擴展同名方法,意外導(dǎo)致方法復(fù)寫,從而在程序運行時出現(xiàn)問題,甚至導(dǎo)致 Crash。

    為此,我們在集成準入檢查中加入了方法覆蓋檢查。當然,如果父類設(shè)計之初本身是希望子類復(fù)寫,我們在 Lint 過程中通常會忽略這些合法的復(fù)寫情況。

    對于這類跨編譯單元的分析需求,如果我們按照 Clang Static Analyser 是較難分析的,但是 Hades 就可以非常輕松地做到,因為 Hades 可以輕松獲取整個繼承鏈以及每個類的實現(xiàn)定義。

    Hades 應(yīng)用案例(2):構(gòu)建 HadesDB

    HadesModel 是結(jié)構(gòu)化數(shù)據(jù),因此,我們也可以將這些模型數(shù)據(jù)以 Document 的形式存儲到文檔型數(shù)據(jù)庫中,例如:CouchDB。

    在 CouchDB 的基礎(chǔ)上建立模型數(shù)據(jù)庫,這樣便能夠方便地通過 Map-Reduce 建立視圖文檔(Design Documents),然后,我們可以獲取項目中包含的類及其方法列表、分析每個 Document 的字段按需輸出結(jié)果。

    例如,存儲建立完整的項目 HadesModel 數(shù)據(jù)后,在 CouchDB 中建立 Design Document,然后在 Map Function 中編寫以下代碼:

    function (doc) {if (doc.extracontext.macro_list !== null) {emit(doc._id, doc.extracontext.macro_list);} }

    CouchDB 支持 JS 代碼編寫 map-reduce,以上代碼表示在當前的數(shù)據(jù)庫中,對于每個 HadesModel Document 判斷是否存在宏定義,如果存在,那么輸出宏定義作為 Design Document 的結(jié)果。

    最后,通過 CouchDB 接口返回可以獲取如下結(jié)果:

    // App 項目中源碼中使用的所有宏定義信息: {"total_rows": xxx,"offset": 0,"rows": [{"id": "NVShopInfoBlackPearlMultiDealCell","key": "NVShopInfoBlackPearlMultiDealCell","value": [{"name": "NVActionSheet","expanded": true,"expandstr": "UIResponder<NVActionSheetDelegate> *","location": ${path_location},...}]},...] }

    有了 HadesDB 以后,我們能賦予代碼語義分析更大的想象空間。比如,可以利用 HadesDB 制作 Web 項目,通過 Web 頁面搜索、查詢我們所需要知道的語義信息和分析數(shù)據(jù)。

    總結(jié)

    本文介紹了在美團點評業(yè)務(wù)快速發(fā)展背景下,針對大型移動項目的靜態(tài)分析需求,結(jié)合開源項目利弊,最終設(shè)計實現(xiàn)的靜態(tài)分析框架 Hades。

    Hades 作為大眾點評移動研發(fā)的基礎(chǔ)設(shè)施之一,在實踐中得到了廣泛的應(yīng)用,為大型 App 項目的日常維護、代碼分析提供支持。基于 HadesModel 的靜態(tài)分析易上手,開發(fā)接入成本低,能夠理解代碼語義,具備全局分析能力等諸多優(yōu)點。

    最后,我們也希望 Hades 的設(shè)計是賦予創(chuàng)造能力的能力,而不僅僅是作為傳統(tǒng)意義上的 Lint 輔助工具,這也是我們?yōu)槭裁床蝗∶麨椤肮ぞ摺?#xff0c;而是稱之為“框架”的原因。當然,基于 Hades 我們也是能夠很方便地制作出 Lint 工具的。

    Hades 是否開源?不久將會開源,敬請期待。如果對我們平臺感興趣,歡迎小伙伴們加入大眾點評的大家庭。

    參考資料

    • [1] Clang 8 documentation
    • [2] Infer static analyzer
    • [3] Clang Tidy
    • [4] OCLint static analyzer
    • [5] Apache CouchDB
    • [6] TypeScript
    • [7] ATD
    • [8] Lazy.js
    • [9] xcpretty
    • [10] Visual Studio Code

    作者簡介

    • 吳達,大眾點評 iOS 技術(shù)專家,Hades 項目開發(fā)者。目前專注于移動 CI 研發(fā),靜態(tài)分析和點評 App 業(yè)務(wù)研發(fā)。
    • 智聰,移動信息組件負責人,大眾點評 iOS 高級專家。專注于移動工具鏈開發(fā),對移動持續(xù)集成、靜態(tài)分析平臺建設(shè)有深刻理解和豐富的實踐經(jīng)驗。

    招聘信息

    大眾點評移動研發(fā)中心,Base 上海,為美團提供移動端底層基礎(chǔ)設(shè)施服務(wù),包含網(wǎng)絡(luò)通信、移動監(jiān)控、推送觸達、動態(tài)化引擎、移動研發(fā)工具等。同時團隊還承載流量分發(fā)、UGC、內(nèi)容生態(tài)、個人中心等業(yè)務(wù)研發(fā)工作,長年虛位以待專注于移動端研發(fā)的各路英雄豪杰。歡迎投遞簡歷:dawei.xing@dianping.com。

    總結(jié)

    以上是生活随笔為你收集整理的Hades:移动端静态分析框架的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    亚洲,国产成人av | 激情久久久久久久久久久久久久久久 | 在线观看精品一区 | 狠狠干夜夜爽 | 日韩久久影院 | 亚一亚二国产专区 | 91天天操 | 久久久福利视频 | 亚洲免费激情 | 国产玖玖在线 | 国产精品视频免费看 | 精品99在线视频 | 日韩乱码在线 | 亚洲乱码中文字幕综合 | 女女av在线 | 69久久久| 久久久私人影院 | 国产99久久九九精品免费 | 色偷偷人人澡久久超碰69 | 久草在线观看视频免费 | av一级一片 | 日韩精品一区二区三区在线视频 | 色婷婷综合久久久久中文字幕1 | 欧美激情综合色综合啪啪五月 | 日韩成人欧美 | 在线观看黄网 | 免费日韩电影 | 国产不卡免费 | 国产999久久久 | 久草在线免费色站 | 欧美性生活大片 | 久久久国产精品久久久 | 色橹橹欧美在线观看视频高清 | 婷婷av色综合 | 成人91在线观看 | 一区二区三区在线观看 | 丁香5月婷婷久久 | 激情综合五月网 | 国产精品久久久久久久久久妇女 | 激情大尺度视频 | 国产黄色一级片 | 91九色在线| 久色 网 | 日日狠狠 | 日韩一区二区三区在线看 | 九九热免费观看 | 97成人在线观看视频 | 91麻豆精品国产自产在线 | 精品自拍网 | 毛片网站免费 | 欧美午夜一区二区福利视频 | 人人添人人澡人人澡人人人爽 | 久久久久久免费视频 | 精品免费视频 | 日本高清dvd | 久久久综合香蕉尹人综合网 | 91完整版 | 久久久久亚洲国产精品 | 欧美性色综合网站 | 成人在线观看影院 | 欧美在线视频一区二区三区 | 中文字幕乱码在线播放 | 91原创在线观看 | 一区二区三区高清不卡 | 日产乱码一二三区别免费 | 黄色片视频在线观看 | 91av视屏| 色99色| 亚洲视频精选 | 欧美日韩视频一区二区三区 | 国产精品va | 久久精品国产免费看久久精品 | 成人黄色视| 丁香5月婷婷久久 | 亚洲精品在线免费 | 婷婷丁香久久五月婷婷 | 国产一级一级国产 | 欧美日韩在线看 | 免费av黄色 | 亚洲精品一区二区网址 | 久久久黄视频 | 亚洲综合小说电影qvod | 激情综合中文娱乐网 | 国产香蕉97碰碰碰视频在线观看 | 国产第一页在线播放 | 久久激情五月丁香伊人 | 亚洲精品国产综合99久久夜夜嗨 | 日韩理论电影在线观看 | 亚洲免费专区 | 国产免费人成xvideos视频 | 五月婷激情 | 国产精品毛片一区视频播不卡 | 日韩av电影中文字幕在线观看 | 成人黄色电影在线观看 | 在线观看 国产 | 在线播放国产一区二区三区 | 久久久久久久综合色一本 | 午夜精品99久久免费 | 久久免费视频网站 | 欧美日韩国产精品一区二区亚洲 | 丁香视频 | 中文字幕制服丝袜av久久 | 免费h在线观看 | 男女啪啪免费网站 | 久久免费看av | 久久色中文字幕 | 国产伦理一区二区三区 | 欧美一区二区三区在线观看 | 日韩a在线观看 | 香蕉影视 | 久草久草在线观看 | 国产黄色大片免费看 | 国产精品欧美久久久久三级 | 在线a亚洲视频播放在线观看 | 麻豆视频91| 亚洲欧美日韩中文在线 | 91天天操 | 久久se视频 | 中文字幕日韩无 | 中文字幕电影高清在线观看 | 在线观看国产区 | 视频国产在线观看18 | 国产黄色片免费观看 | 天天操偷偷干 | 国产亚洲免费的视频看 | 美女视频一区 | 一级黄色片在线 | 狠狠色狠狠色合久久伊人 | 毛片网站免费 | 视频精品一区二区三区 | 欧美午夜性 | 国产精品美女久久久久久网站 | 日本不卡一区二区 | 亚洲视频大全 | 久久视频在线看 | 午夜aaaa| 免费毛片aaaaaa| 日韩欧美不卡 | 97天天综合网 | 欧美激情综合网 | 日本字幕网 | 日本激情视频中文字幕 | 黄色在线看网站 | 国产在线观看91 | 国产精品夜夜夜一区二区三区尤 | 国产中文字幕亚洲 | 一区二区三区在线视频观看58 | 五月婷婷视频在线观看 | 蜜臀av夜夜澡人人爽人人桃色 | 免费碰碰| 日产乱码一二三区别免费 | 亚洲欧美视频网站 | 在线观看黄av | 成人羞羞视频在线观看免费 | 超碰午夜 | 在线观看视频 | 国产精品福利在线播放 | 手机av观看| 在线a视频免费观看 | 国产精品乱码一区二三区 | 亚洲精品国内 | 国产亚洲精品久久久网站好莱 | 中国成人一区 | 亚洲精品小视频 | 国产色在线,com | 在线视频 一区二区 | 在线婷婷| 亚洲综合激情小说 | 国产粉嫩在线观看 | 国产精品99久久久久的智能播放 | 8x成人在线 | 欧美日韩调教 | 在线 视频 亚洲 | 中文字幕999 | 91福利视频免费 | 亚洲涩综合 | 婷婷综合 | 午夜视频黄 | 婷婷久久久久 | 69久久夜色精品国产69 | 欧美日韩观看 | 九九免费在线观看 | 久草在线免费看视频 | 一区二区三区精品久久久 | 国产亚洲欧洲 | 久久精品视频在线 | 国产精品v欧美精品v日韩 | 天天性天天草 | 欧美激情精品 | 国产成人l区| 国产专区视频在线观看 | 天堂资源在线观看视频 | 国产精品一区二区三区久久久 | www.精选视频.com| 精品国产中文字幕 | 日韩中文字幕在线不卡 | 天天综合网入口 | 久久久久亚洲精品成人网小说 | 日韩综合视频在线观看 | 精品久久久久一区二区国产 | 久草网视频在线观看 | 久久婷婷丁香 | 久久免费在线观看 | 欧美视频在线观看免费网址 | 欧美地下肉体性派对 | 国产在线视频一区二区 | 亚洲一区精品二人人爽久久 | 久久久久久久久国产 | 18久久久久 | 在线观看岛国av | 亚洲精品国产精品国 | 国产精品免费小视频 | 国产在线精品一区二区 | 夜夜躁日日躁狠狠久久av | 国产伦理久久精品久久久久_ | 天天干天天操天天爱 | 中文资源在线官网 | 天天摸天天舔天天操 | 少妇bbbb| 在线激情av电影 | 国产在线中文 | 欧洲av不卡 | 日韩色爱 | 免费91在线 | 日韩欧美黄色网址 | 亚洲精品午夜国产va久久成人 | 在线观看免费一区 | 狠狠色网 | 中文字幕不卡在线88 | 黄色免费大全 | 天天干.com| 91精品1区| 婷婷六月天综合 | 亚洲人天堂 | 日韩亚洲在线观看 | 91精品久久久久久久久久久久久 | 99久久99热这里只有精品 | 在线观看电影av | 在线观看视频黄色 | 国产精品一级视频 | 中文字幕在线观看三区 | 天天综合网在线观看 | 天天操人人干 | 日本三级久久 | 日韩欧美视频一区 | 在线中文字幕网站 | 天天干.com | 久久久久北条麻妃免费看 | 一级黄毛片 | 成人三级网站在线观看 | 少妇性bbb搡bbb爽爽爽欧美 | 中文字幕一区二区三区视频 | 在线播放日韩 | 久久综合狠狠狠色97 | 国产精品高清av | 精品免费观看 | 国产精品尤物 | 97视频在线观看视频免费视频 | 国产无遮挡又黄又爽在线观看 | 成年免费在线视频 | 久久精品国产第一区二区三区 | 亚洲精品91天天久久人人 | 国产v欧美 | 97人人模人人爽人人喊中文字 | 国内精品视频在线播放 | 久草在线| 91成人在线观看高潮 | 在线免费观看欧美日韩 | 免费在线观看黄 | 国产中文字幕视频在线观看 | 国产亚洲精品久久网站 | 中文字幕免费观看 | 热久久国产 | 国产精品久久久久久一区二区三区 | 国产成人综 | 亚洲特级毛片 | 乱男乱女www7788| 亚洲天天在线 | 久久精品成人热国产成 | 91看片淫黄大片在线播放 | 国产视频一区精品 | 日韩精品中字 | 欧美一级大片在线观看 | 天天操天天舔天天干 | 亚洲日本国产 | 人人爽人人舔 | 天天操天天干天天操天天干 | 毛片3 | 天天操天天操天天操天天操天天操 | 久久久久国产精品www | 国产品久精国精产拍 | 狠狠色狠狠色综合日日92 | 91精品视频免费看 | 色小说av | 天天色天天爱天天射综合 | 激情五月综合网 | 在线看日韩av | 精品美女在线视频 | 91av影视 | 欧美日韩视频精品 | 91精彩在线视频 | 三级av免费看 | 亚洲黄色三级 | 中文字幕在线观看1 | 人人cao | 亚州精品天堂中文字幕 | 久久tv| 午夜在线免费观看视频 | 国产精品美女久久久久久网站 | 日日爱夜夜爱 | 亚洲电影久久久 | 色狠狠操 | 欧美另类性 | 亚洲精品国产片 | 欧美 日韩 成人 | 精品久久精品久久 | 免费看特级毛片 | 日韩在线中文字幕 | 成人av久久 | 91av播放 | 日韩精品一区二区不卡 | 国产在线看 | 国产精品久久久区三区天天噜 | 久久亚洲视频 | 精品在线视频观看 | 国产91精品一区二区麻豆亚洲 | 最近中文字幕免费av | 在线亚洲精品 | 91精品影视 | 综合色久 | 中文久草| 在线亚洲成人 | 日韩免费观看一区二区三区 | 亚洲成人资源在线观看 | 久久久精品福利视频 | 亚洲三级在线播放 | 日韩电影中文,亚洲精品乱码 | 国产看片免费 | 精品国产乱码久久久久久1区二区 | 91亚洲精品乱码久久久久久蜜桃 | www色,com| 国产在线久久久 | 在线看不卡av | 成人av免费在线 | 午夜精品久久久久久久99无限制 | 九九热精品国产 | 91成人精品国产刺激国语对白 | 国产精品区二区三区日本 | 精品久久久亚洲 | 麻豆精品视频在线观看免费 | 久久国色夜色精品国产 | 亚洲理论在线观看 | 亚洲精品www久久久久久 | 国产一二三四在线观看视频 | 天天做夜夜做 | 狠狠干狠狠色 | 国产不卡av在线 | 成人av在线看 | 丁香 久久 综合 | 一区二区 精品 | 人人澡人人澡人人 | 国产精品永久免费 | 日韩免费电影网站 | 国产亚洲视频在线观看 | 欧美一级裸体视频 | 久久久久久久久黄色 | 九九九在线观看视频 | 国产三级在线播放 | 午夜精品区 | 久久精品com | 91黄色在线视频 | 欧美一级黄大片 | 青青河边草观看完整版高清 | 亚洲激情在线观看 | 日韩在线电影一区二区 | 4438全国亚洲精品观看视频 | 久久在线免费观看视频 | 91精品一区二区三区蜜桃 | 国产精品久久久久久久电影 | 国产精品一区二区三区四区在线观看 | 成人一区二区三区在线 | 最近高清中文字幕在线国语5 | 色婷婷成人| 欧美色道 | 美女视频黄色免费 | 久久久久久美女 | 久草网视频在线观看 | 成人影音av | 在线日韩亚洲 | 国产一区二区日本 | 国产成人久久 | 亚洲国产精品99久久久久久久久 | 国产精品久久毛片 | 一区二区理论片 | 中文区中文字幕免费看 | 国产理论片在线观看 | av大全免费在线观看 | 91在线区 | 免费看的黄色的网站 | 黄色软件在线观看 | 国产视频在线免费观看 | 青青河边草免费观看完整版高清 | 五月天亚洲婷婷 | 婷婷av网站 | 亚洲精品视频第一页 | 天天摸天天舔天天操 | 免费人人干 | 亚洲天天干 | 久久免费视频在线观看 | 网站在线观看日韩 | 一区二区三区福利 | 久久久久久久av | 欧美激情精品久久久久久免费 | 天天干夜夜夜 | japanesefreesexvideo高潮 | 91九色国产蝌蚪 | 欧美最猛性xxxxx免费 | 亚洲成人网av | 日韩在线视| 97免费在线观看视频 | 九九日九九操 | 午夜国产一区二区三区四区 | 欧美视频xxx | 国产福利在线不卡 | 91成年人视频 | 成人h视频| 久久超碰网 | 成人免费看电影 | 日韩精品大片 | 午夜黄色 | 欧美不卡在线 | 午夜体验区 | 手机看片 | 在线观看黄色国产 | 九月婷婷人人澡人人添人人爽 | 视频一区二区在线观看 | 天天干com | 999成人网 | 久久视屏网| 99草视频| 人人澡超碰碰 | 久久久www成人免费精品张筱雨 | 欧美色综合 | 69av视频在线观看 | 国产精品美女久久久久久久久久久 | 国产精品久久久久久久午夜 | 久久精品99国产精品亚洲最刺激 | 日韩理论影院 | 在线观看色网 | 在线看一区二区 | 色天天综合久久久久综合片 | 中文字幕制服丝袜av久久 | 在线观看视频你懂 | 亚洲精品国产麻豆 | 成年人网站免费观看 | 久久综合色婷婷 | 狠狠干狠狠色 | 国产精品一区二区电影 | 国产91精品看黄网站在线观看动漫 | 国产综合精品一区二区三区 | 久久精品国产久精国产 | 97精品国自产拍在线观看 | 91av免费看 | 波多野结衣在线播放视频 | 69国产在线观看 | 蜜臀久久99精品久久久无需会员 | 欧美久久久一区二区三区 | 911在线| 蜜臀aⅴ精品一区二区三区 久久视屏网 | 九九九热精品免费视频观看 | 操操操日日日干干干 | 国产一区在线视频 | 国产精品午夜久久久久久99热 | 亚洲 欧美 变态 国产 另类 | 成年人国产在线观看 | 久久久久国产精品午夜一区 | 欧美日韩高清一区二区三区 | 久久露脸国产精品 | 国产成人精品一区二 | 国产一区二区三区网站 | 国内视频一区二区 | 免费视频黄色 | 在线观看成人毛片 | 亚洲激精日韩激精欧美精品 | 特级毛片在线 | 99久久99久久 | 国产精品欧美一区二区三区不卡 | 亚洲 欧洲av| 超碰99在线 | 韩国av一区二区 | 91在线免费公开视频 | 成人影视免费看 | 激情五月婷婷 | 国产资源站 | 免费网站在线观看人 | 国产精品久久一卡二卡 | 免费高清在线观看成人 | 免费在线观看av网址 | 欧美精品乱码久久久久久按摩 | 国产精品成人国产乱 | 婷婷六月中文字幕 | 天天干国产| 久久久www免费电影网 | 中文字幕最新精品 | 这里只有精品视频在线 | 狠狠婷婷 | 91麻豆精品国产91久久久无限制版 | 日韩在线不卡视频 | 中文字幕中文字幕在线中文字幕三区 | 九九精品久久 | 欧美日韩国产在线 | 欧美中文字幕久久 | 美女网站视频久久 | 99精品国自产在线 | 九九九热精品免费视频观看 | 免费福利在线播放 | 日韩剧 | 成人综合日日夜夜 | 色久网 | 久久综合九色欧美综合狠狠 | 亚洲色影爱久久精品 | 人人爽人人干 | 激情综合电影网 | 国产精品都在这里 | 欧美成人在线网站 | www.超碰 | 欧美激情视频久久 | 国产精品999久久久 久产久精国产品 | 一区二区亚洲精品 | 99精品热视频只有精品10 | 射久久久 | 欧美日韩精品在线一区二区 | 国产亚洲精品久 | www.香蕉视频在线观看 | 狠狠色伊人亚洲综合网站色 | 17婷婷久久www | 久久综合色婷婷 | 久久久国产一区 | 日韩免费看 | 波多野结衣视频一区 | 国产99久久久国产精品免费二区 | 人人天天夜夜 | 国产小视频在线观看 | 国产成人区| 五月天综合网站 | av中文字幕在线观看网站 | 久久综合久久久 | 国产精品一区在线播放 | 高清视频一区 | 国产精品视频免费看 | 黄av免费| 奇米网网址 | 最新中文字幕在线播放 | 97电影网手机版 | 欧美国产日韩一区 | 麻豆视频在线免费观看 | 特级毛片aaa | 国产96精品 | 九九热只有精品 | 日批视频 | 久99久视频 | 人人干人人干人人干 | 日本中文字幕观看 | 中文字幕在线观看日本 | 欧美日韩xxxxx| 亚洲精品国偷自产在线91正片 | 在线免费看黄网站 | www.久久com| av在线色| 天天看天天操 | 亚洲另类人人澡 | 久久系列| 色婷婷狠狠五月综合天色拍 | 91成人精品一区在线播放 | 中文字幕在线观看免费 | 久久国产成人午夜av影院宅 | 国产99久久九九精品免费 | av在线免费网 | 看污网站 | 99精品一区 | 国产手机在线视频 | 日韩黄色网络 | 国产99久久久国产精品成人免费 | 欧美五月婷婷 | 超碰在线成人 | 色网站在线免费观看 | 黄色免费高清视频 | 亚洲高清视频一区二区三区 | 国产中文字幕在线 | 午夜在线看 | 色婷婷在线播放 | 午夜色场| 久草精品在线观看 | 香蕉视频最新网址 | 久久er99热精品一区二区 | 欧美日本国产在线观看 | 91精品对白一区国产伦 | 国产成人黄色av | 免费a v在线 | av综合av | 蜜臀久久99精品久久久无需会员 | 久久久久中文字幕 | 亚洲午夜久久久综合37日本 | 国产精品久久久久久久免费大片 | 亚洲电影网站 | 激情丁香综合五月 | 国产色在线观看 | 99精品免费在线观看 | 美女一级毛片视频 | 日日夜夜狠狠干 | 日韩一区精品 | 国产探花在线看 | 成人在线电影观看 | 91观看视频 | 婷婷综合导航 | 日韩视频精品在线 | av三级av| 久久激情视频 久久 | 久草在线在线精品观看 | 亚洲砖区区免费 | 亚洲综合色婷婷 | 国产成人一区二区在线观看 | 亚洲mv大片欧洲mv大片免费 | 色综合久久五月天 | 国产91大片| 伊人久久五月天 | 久草视频在线播放 | 在线成人一区二区 | 97精品国产手机 | 丝袜足交在线 | 久久中文字幕导航 | 91福利视频免费 | 国产欧美精品一区二区三区 | 久久成熟 | 伊人婷婷网 | 免费视频 你懂的 | 欧美日韩国产精品一区二区亚洲 | 伊人网av| 日韩在线视频播放 | 久久久国产影视 | 日本中文字幕网 | 久久久久久久久网站 | 最近中文字幕国语免费av | 91精品一区二区三区久久久久久 | 天天射网站 | 美女免费黄网站 | 少妇bbr搡bbb搡bbb | 九九激情视频 | 在线观看一区 | 在线观看av免费观看 | 国产精品久久久久久久久久久久午 | 蜜桃视频日韩 | 天天色天天操天天爽 | 在线成人短视频 | 特及黄色片 | 国产精品你懂的在线观看 | 1区2区视频 | 四虎在线影视 | 国产又黄又爽无遮挡 | 日本乱码在线 | 久久香蕉国产精品麻豆粉嫩av | 激情五月亚洲 | 免费a一级 | 久久99深爱久久99精品 | 日韩精品免费一区二区 | 激情五月综合网 | 人人狠狠综合久久亚洲 | 国产一区二区三区 在线 | 天天综合狠狠精品 | 国产精品免费在线播放 | 成人精品电影 | 久久久精品一区二区三区 | 亚洲一区二区三区毛片 | 亚洲香蕉在线观看 | 亚洲精品网址在线观看 | 亚洲 欧美日韩 国产 中文 | 久久久在线 | 亚洲精品456在线播放 | www好男人 | 久草在线免费色站 | 色激情在线 | 亚洲禁18久人片 | 成人久久综合 | 在线观看黄网站 | 亚洲精品国偷自产在线99热 | 毛片精品免费在线观看 | 国产又粗又猛又爽又黄的视频免费 | 国产精品久久久久久久7电影 | 99久久综合国产精品二区 | 91视频高清免费 | 国产视频精品久久 | 四虎8848免费高清在线观看 | 国产a国产a国产a | 午夜久久视频 | 国产青草视频在线观看 | 午夜精品久久久久久久99水蜜桃 | 国产一级免费播放 | 91丨九色丨蝌蚪丨对白 | 亚洲最新av在线网址 | 免费欧美| 久久成人国产精品免费软件 | 人人爽人人干 | 五月婷婷在线视频观看 | 欧美国产精品一区二区 | 狠狠干我| 国产伦理精品一区二区 | 成人cosplay福利网站 | 91精品在线免费视频 | 97色涩 | 精品亚洲一区二区三区 | 免费久久网站 | 中文在线免费一区三区 | 999久久国精品免费观看网站 | 在线免费黄网站 | 亚洲一区久久 | 中文字幕第一页av | 91亚洲精品久久久久图片蜜桃 | 五月婷婷黄色网 | av一级免费 | 亚洲国产精品久久久 | 国产精品观看视频 | 日韩一区在线播放 | 国产精品久久99综合免费观看尤物 | 激情视频免费观看 | 日日噜噜噜噜夜夜爽亚洲精品 | 伊人国产女 | 一区二区欧美激情 | 国产精品毛片一区视频 | 国产成人一区二区三区影院在线 | 久草在线免费资源站 | 中文字幕精品一区二区精品 | 亚洲精品高清一区二区三区四区 | 伊人影院99 | 一区二区三区韩国免费中文网站 | 夜夜高潮夜夜爽国产伦精品 | 中文字幕精品一区二区三区电影 | 操操操人人人 | 日韩 精品 一区 国产 麻豆 | 人人干人人搞 | 91丨九色丨高潮 | 国产日产欧美在线观看 | 日精品在线观看 | 六月婷色| 九九有精品 | 五月婷婷狠狠 | 日韩色在线 | 成人免费一区二区三区在线观看 | 天天伊人狠狠 | 五月天亚洲综合 | www.在线观看av | 成年人在线免费看 | 中文字幕在线影院 | 欧美日韩国产精品爽爽 | 成年人电影免费在线观看 | 久久9999久久 | 国产高清成人 | 久久久久久国产精品 | 午夜少妇| 久久久久久久久黄色 | 国产一区二区不卡在线 | 最近av在线 | 五月天激情视频在线观看 | 欧美精彩视频在线观看 | 日韩av中文字幕在线 | 久久精品国产成人精品 | 国产美女精品视频免费观看 | 91精品国产三级a在线观看 | 中文字幕人成乱码在线观看 | 精品国产自 | 91精品在线视频观看 | 在线电影a | 国产手机在线精品 | 日本精品一区二区三区在线观看 | 日韩在线视频观看免费 | 亚洲精品视频在线播放 | 国产精品第一视频 | 人人爽网站 | 亚洲精品美女在线观看播放 | 欧美成人影音 | 日韩黄色大片在线观看 | 97夜夜澡人人爽人人免费 | 97在线观看免费观看 | 色婷婷www| 国产精品久久久999 国产91九色视频 | 国产精品第三页 | 国产精品美女久久久久久久久久久 | 大荫蒂欧美视频另类xxxx | 久久久久久久久久久电影 | 亚洲狠狠操 | 国产精品99免视看9 国产精品毛片一区视频 | 中文字幕免费播放 | 欧美aaa大片| www.五月天婷婷.com | 国产一卡在线 | 亚洲观看黄色网 | 日韩av一区二区三区四区 | 在线视频观看你懂的 | 日韩欧美高清在线 | 青青草久草在线 | 日韩中文字幕视频在线 | 天天艹天天 | 亚洲欧洲国产精品 | 久久看毛片 | 亚洲一区尤物 | 欧女人精69xxxxxx| av福利电影 | 日韩三级精品 | 欧美人操人 | 婷婷中文字幕 | 亚洲国产精品传媒在线观看 | 久久久 精品 | 少妇视频在线播放 | 久久久久久欧美二区电影网 | 免费视频资源 | 久久精品观看 | 一级a性色生活片久久毛片波多野 | 五月激情片 | 成人午夜电影在线观看 | 日韩久久精品一区 | 在线观看视频日韩 | 亚洲爱av | 欧美国产日韩一区二区 | 国产流白浆高潮在线观看 | 成人一级在线 | 日本视频高清 | 亚洲福利精品 | 国产精品久久久久9999 | 亚洲一级久久 | 国产九九九九九 | 成年人毛片在线观看 | 国产成人精品久久久 | 91香蕉视频在线 | 国产69精品久久99不卡的观看体验 | 欧美日韩中文字幕在线视频 | 日韩精品免费一区二区 | 久草视频手机在线 | 精品欧美一区二区在线观看 | 久久久91精品国产一区二区三区 | 激情综合电影网 | 国产成人精品久久久 | 最新日韩在线观看 | 精品视频免费久久久看 | 在线黄网站 | 一区二区三区四区不卡 | 天天干天天色2020 | 在线观看亚洲精品视频 | 在线观看中文字幕第一页 | 亚洲精品国偷拍自产在线观看 | 国产精品一区在线播放 | 亚洲天堂精品视频 | 超碰精品在线 | 美女视频黄,久久 | 色之综合网 | 青青久视频 | 99久久99热这里只有精品 | 国产视频精品在线 | 精品一二三区视频 | 97超级碰碰碰视频在线观看 | 国产成年免费视频 | 五月开心六月伊人色婷婷 | 亚洲91网站 | 成人久久18免费 | 精品自拍网 | 国产亚洲精品bv在线观看 | 香蕉视频91 | 欧美日韩国产色综合一二三四 | 波多野结衣视频在线 | 国产黄在线免费观看 | 精品久久久久一区二区国产 | 午夜精品福利影院 | 精品三级av | 91高清免费在线观看 | av国产在线观看 | 亚洲欧美国产视频 | 韩国精品一区二区三区六区色诱 | 黄色特级一级片 | 免费观看91 | 蜜臀一区二区三区精品免费视频 | 亚洲区二区 | 精品国产乱码久久 | 亚洲国产精品成人女人久久 | 欧美一区,二区 | 五月天综合色激情 | 夜夜摸夜夜爽 | av在线免费不卡 | 91中文字幕网 | 6080yy精品一区二区三区 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 最近中文字幕完整高清 | 插综合网| 91久久久久久久一区二区 | 久草在线91 | 黄色软件视频大全免费下载 | 亚洲最新av在线网站 | 丁香五月网久久综合 | 黄色精品久久 | 四虎5151久久欧美毛片 | 久久99中文字幕 | 亚洲成人精品影院 | 国产免费视频在线 | 国产精品美女 | 在线之家免费在线观看电影 | 最新日韩视频在线观看 | 欧美日韩一区二区在线观看 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 97香蕉久久国产在线观看 | 日韩啪视频 | 在线观看mv的中文字幕网站 | 久久久久亚洲最大xxxx | av观看在线观看 | 国产视频在线观看免费 | 成年人免费在线观看网站 | 午夜精品久久久 | 日日夜夜精品视频 | 国产精品久久久久久一二三四五 | 免费在线一区二区三区 | 激情久久久久 | 天堂av在线网 | 一级片色播影院 | 91麻豆精品国产91久久久久久久久 | 91精品国产91热久久久做人人 | 国产一卡在线 | 亚洲 综合 国产 精品 | 国产精品美女视频 | 激情视频二区 | 日韩精品专区 | 日韩精品在线看 | 国产九九热视频 | 涩涩网站在线观看 | 久久久国产影视 | 精品国产一区二区三区久久影院 | 久久精品久久精品久久精品 | 在线看日韩 | 国产视频精选 | av电影在线不卡 | 色老板在线视频 | av电影免费 | 超碰97人| 久久成人18免费网站 | 欧美一区二区三区在线 | 国产伦精品一区二区三区在线 | 日韩高清免费电影 | 丁香六月在线 | 久久久久福利视频 | 福利网在线 | 九色在线视频 | 欧美久久久久 | 午夜精品久久久久久久久久久 | 日日操操| 麻花天美星空视频 | 97国产在线观看 | 日日干影院 | 99热.com | 亚洲黄色免费在线看 | 亚洲国产精品人久久电影 | 婷婷色六月天 | 国产精品久久电影观看 | 日日夜夜天天久久 | 久久国产区 | 一级α片免费看 | 中文字幕在线日亚洲9 | 五月婷婷激情综合 | 国产亚洲人 | 夜夜躁狠狠躁日日躁视频黑人 | 国产精品久久久久久一区二区 | a视频在线观看免费 | 91色国产在线 | 美女黄久久 | 99国产精品 | 一级黄色电影网站 | 欧美一级久久久久 | 国产精品手机看片 | 久久精品欧美一区二区三区麻豆 | 黄色一级大片在线观看 | 成人试看120秒 | 色婷婷国产精品一区在线观看 | 丁香激情视频 | 九草视频在线观看 | 最近最新中文字幕视频 | 欧美成人黄 | 色多多视频在线观看 | 欧美日韩精品在线 | 精品高清视频 | 久久你懂的 | 97av在线视频免费播放 | 免费国产在线精品 | 国产中文字幕网 | 成人免费在线观看av | 亚洲精品黄色在线观看 | a v在线视频 | 亚洲综合色站 | 在线免费试看 | 国产精品va| 中文在线字幕免费观 | 91精品在线免费视频 | 亚洲区色 | 99综合影院在线 | 中文字幕在线视频网站 |