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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

美团Android DEX自动拆包及动态加载简介

發布時間:2025/3/15 Android 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 美团Android DEX自动拆包及动态加载简介 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概述

作為一個android開發者,在開發應用時,隨著業務規模發展到一定程度,不斷地加入新功能、添加新的類庫,代碼在急劇的膨脹,相應的apk包的大小也急劇增加, 那么終有一天,你會不幸遇到這個錯誤:

  • 生成的apk在android 2.3或之前的機器上無法安裝,提示INSTALL_FAILED_DEXOPT
  • 方法數量過多,編譯時出錯,提示: Conversion to Dalvik format failed:Unable to execute dex: method ID not in [0, 0xffff]: 65536
  • 而問題產生的具體原因如下:

  • 無法安裝(Android 2.3 INSTALL_FAILED_DEXOPT)問題,是由dexopt的LinearAlloc限制引起的,在Android版本不同分別經歷了4M/5M/8M/16M限制,目前主流4.2.x系統上可能都已到16M, 在Gingerbread或者以下系統LinearAllocHdr分配空間只有5M大小的, 高于Gingerbread的系統提升到了8M。Dalvik linearAlloc是一個固定大小的緩沖區。在應用的安裝過程中,系統會運行一個名為dexopt的程序為該應用在當前機型中運行做準備。dexopt使用LinearAlloc來存儲應用的方法信息。Android 2.2和2.3的緩沖區只有5MB,Android 4.x提高到了8MB或16MB。當方法數量過多導致超出緩沖區大小時,會造成dexopt崩潰。

  • 超過最大方法數限制的問題,是由于DEX文件格式限制,一個DEX文件中method個數采用使用原生類型short來索引文件中的方法,也就是4個字節共計最多表達65536個method,field/class的個數也均有此限制。對于DEX文件,則是將工程所需全部class文件合并且壓縮到一個DEX文件期間,也就是Android打包的DEX過程中, 單個DEX文件可被引用的方法總數(自己開發的代碼以及所引用的Android框架、類庫的代碼)被限制為65536;

  • 插件化? MultiDex?

    解決這個問題,一般有下面幾種方案,一種方案是加大Proguard的力度來減小DEX的大小和方法數,但這是治標不治本的方案,隨著業務代碼的添加,方法數終究會到達這個限制,一種比較流行的方案是插件化方案,另外一種是采用google提供的MultiDex方案,以及google在推出MultiDex之前Android Developers博客介紹的通過自定義類加載過程, 再就是Facebook推出的為Android應用開發的Dalvik補丁, 但facebook博客里寫的不是很詳細;我們在插件化方案上也做了探索和嘗試,發現部署插件化方案,首先需要梳理和修改各個業務線的代碼,使之解耦,改動的面和量比較巨大,通過一定的探討和分析,我們認為對我們目前來說采用MultiDex方案更靠譜一些,這樣我們可以快速和簡潔的對代碼進行拆分,同時代碼改動也在可以接受的范圍內; 這樣我們采用了google提供的MultiDex方式進行了開發。

    插件化方案在業內有不同的實現原理,這里不再一一列舉,這里只列舉下Google為構建超過65K方法數的應用提供官方支持的方案:MultiDex。

    首先使用Android SDK Manager升級到最新的Android SDK Build Tools和Android Support Library。然后進行以下兩步操作:

    1.修改Gradle配置文件,啟用MultiDex并包含MultiDex支持:

    android {compileSdkVersion 21 buildToolsVersion "21.1.0"defaultConfig {...minSdkVersion 14targetSdkVersion 21...// Enabling MultiDex support.MultiDexEnabled true}...}dependencies { compile 'com.android.support:MultiDex:1.0.0' }

    2.讓應用支持多DEX文件。在官方文檔中描述了三種可選方法:

    在AndroidManifest.xml的application中聲明android.support.MultiDex.MultiDexApplication;
    如果你已經有自己的Application類,讓其繼承MultiDexApplication;
    如果你的Application類已經繼承自其它類,你不想/能修改它,那么可以重寫attachBaseContext()方法:

    @Override protected void attachBaseContext(Context base) {super.attachBaseContext(base);MultiDex.install(this); }

    并在Manifest中添加以下聲明:

    <?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.android.MultiDex.myapplication"><application...android:name="android.support.MultiDex.MultiDexApplication">...</application></manifest>

    如果已經有自己的Application,則讓其繼承MultiDexApplication即可.

    Dex自動拆包及動態加載

    MultiDex帶來的問題

    在第一版本采用MultiDex方案上線后,在Dalvik下MultiDex帶來了下列幾個問題:

  • 在冷啟動時因為需要安裝DEX文件,如果DEX文件過大時,處理時間過長,很容易引發ANR(Application Not Responding);
  • 采用MultiDex方案的應用可能不能在低于Android 4.0 (API level 14) 機器上啟動,這個主要是因為Dalvik linearAlloc的一個bug (Issue 22586);
  • 采用MultiDex方案的應用因為需要申請一個很大的內存,在運行時可能導致程序的崩潰,這個主要是因為Dalvik linearAlloc 的一個限制(Issue 78035). 這個限制在 Android 4.0 (API level 14)已經增加了, 應用也有可能在低于 Android 5.0 (API level 21)版本的機器上觸發這個限制;
  • 而在ART下MultiDex是不存在這個問題的,這主要是因為ART下采用Ahead-of-time (AOT) compilation技術,系統在APK的安裝過程中會使用自帶的dex2oat工具對APK中可用的DEX文件進行編譯并生成一個可在本地機器上運行的文件,這樣能提高應用的啟動速度,因為是在安裝過程中進行了處理這樣會影響應用的安裝速度,對ART感興趣的可以參考一下ART和Dalvik的區別.

    MultiDex的基本原理是把通過DexFile來加載Secondary DEX,并存放在BaseDexClassLoader的DexPathList中。

    下面代碼片段是BaseDexClassLoader findClass的過程:

    protected Class<?> findClass(String name) throws ClassNotFoundException {List<Throwable> suppressedExceptions = new ArrayList<Throwable>();Class c = pathList.findClass(name, suppressedExceptions);if (c == null) {ClassNotFoundException cnfe = new ClassNotFoundException("Didn't find class \"" + name + "\" on path: " + pathList); for (Throwable t : suppressedExceptions) {cnfe.addSuppressed(t);}throw cnfe;}return c; }

    下面代碼片段為怎么通過DexFile來加載Secondary DEX并放到BaseDexClassLoader的DexPathList中:

    private static void install(ClassLoader loader, List<File> additionalClassPathEntries,File optimizedDirectory)throws IllegalArgumentException, IllegalAccessException,NoSuchFieldException, InvocationTargetException, NoSuchMethodException {/* The patched class loader is expected to be a descendant of* dalvik.system.BaseDexClassLoader. We modify its* dalvik.system.DexPathList pathList field to append additional DEX* file entries.*/Field pathListField = findField(loader, "pathList");Object dexPathList = pathListField.get(loader);ArrayList<IOException> suppressedExceptions = new ArrayList<IOException>();expandFieldArray(dexPathList, "dexElements", makeDexElements(dexPathList,new ArrayList<File>(additionalClassPathEntries), optimizedDirectory,suppressedExceptions));try {if (suppressedExceptions.size() > 0) {for (IOException e : suppressedExceptions) {//Log.w(TAG, "Exception in makeDexElement", e);}Field suppressedExceptionsField =findField(loader, "dexElementsSuppressedExceptions");IOException[] dexElementsSuppressedExceptions =(IOException[]) suppressedExceptionsField.get(loader);if (dexElementsSuppressedExceptions == null) {dexElementsSuppressedExceptions =suppressedExceptions.toArray(new IOException[suppressedExceptions.size()]);} else {IOException[] combined =new IOException[suppressedExceptions.size() +dexElementsSuppressedExceptions.length];suppressedExceptions.toArray(combined);System.arraycopy(dexElementsSuppressedExceptions, 0, combined,suppressedExceptions.size(), dexElementsSuppressedExceptions.length);dexElementsSuppressedExceptions = combined;}suppressedExceptionsField.set(loader, dexElementsSuppressedExceptions);}} catch(Exception e) {} }

    Dex自動拆包及動態加載方案簡介

    通過查看MultiDex的源碼,我們發現MultiDex在冷啟動時容易導致ANR的瓶頸, 在2.1版本之前的Dalvik的VM版本中, MultiDex的安裝大概分為幾步,第一步打開apk這個zip包,第二步把MultiDex的dex解壓出來(除去Classes.dex之外的其他DEX,例如:classes2.dex, classes3.dex等等),因為android系統在啟動app時只加載了第一個Classes.dex,其他的DEX需要我們人工進行安裝,第三步通過反射進行安裝,這三步其實都比較耗時, 為了解決這個問題我們考慮是否可以把DEX的加載放到一個異步線程中,這樣冷啟動速度能提高不少,同時能夠減少冷啟動過程中的ANR,對于Dalvik linearAlloc的一個缺陷(Issue 22586)和限制(Issue 78035),我們考慮是否可以人工對DEX的拆分進行干預,使每個DEX的大小在一定的合理范圍內,這樣就減少觸發Dalvik linearAlloc的缺陷和限制; 為了實現這幾個目的,我們需要解決下面三個問題:

  • 在打包過程中如何產生多個的DEX包?
  • 如果做到動態加載,怎么決定哪些DEX動態加載呢?
  • 如果啟動后在工作線程中做動態加載,如果沒有加載完而用戶進行頁面操作需要使用到動態加載DEX中的class怎么辦?
  • 我們首先來分析如何解決第一個問題,在使用MultiDex方案時,我們知道BuildTool會自動把代碼進行拆成多個DEX包,并且可以通過配置文件來控制哪些代碼放到第一個DEX包中, 下圖是Android的打包流程示意圖:

    為了實現產生多個DEX包,我們可以在生成DEX文件的這一步中, 在Ant或gradle中自定義一個Task來干預DEX產生的過程,從而產生多個DEX,下圖是在ant和gradle中干預產生DEX的自定task的截圖:

    tasks.whenTaskAdded { task ->if (task.name.startsWith('proguard') && (task.name.endsWith('Debug') || task.name.endsWith('Release'))) {task.doLast {makeDexFileAfterProguardJar();}task.doFirst {delete "${project.buildDir}/intermediates/classes-proguard";String flavor = task.name.substring('proguard'.length(), task.name.lastIndexOf(task.name.endsWith('Debug') ? "Debug" : "Release"));generateMainIndexKeepList(flavor.toLowerCase());}} else if (task.name.startsWith('zipalign') && (task.name.endsWith('Debug') || task.name.endsWith('Release'))) {task.doFirst {ensureMultiDexInApk();}} }

    上一步解決了如何打包出多個DEX的問題了,那我們該怎么該根據什么來決定哪些class放到Main DEX,哪些放到Secondary DEX呢(這里的Main DEX是指在2.1版本的Dalvik VM之前由android系統在啟動apk時自己主動加載的Classes.dex,而Secondary DEX是指需要我們自己安裝進去的DEX,例如:Classes2.dex, Classes3.dex等), 這個需要分析出放到Main DEX中的class依賴,需要確保把Main DEX中class所有的依賴都要放進來,否則在啟動時會發生ClassNotFoundException, 這里我們的方案是把Service、Receiver、Provider涉及到的代碼都放到Main DEX中,而把Activity涉及到的代碼進行了一定的拆分,把首頁Activity、Laucher Activity、歡迎頁的Activity、城市列表頁Activity等所依賴的class放到了Main DEX中,把二級、三級頁面的Activity以及業務頻道的代碼放到了Secondary DEX中,為了減少人工分析class的依賴所帶了的不可維護性和高風險性,我們編寫了一個能夠自動分析Class依賴的腳本, 從而能夠保證Main DEX包含class以及他們所依賴的所有class都在其內,這樣這個腳本就會在打包之前自動分析出啟動到Main DEX所涉及的所有代碼,保證Main DEX運行正常。

    隨著第二個問題的迎刃而解,我們來到了比較棘手的第三問題,如果我們在后臺加載Secondary DEX過程中,用戶點擊界面將要跳轉到使用了在Secondary DEX中class的界面, 那此時必然發生ClassNotFoundException, 那怎么解決這個問題呢,在所有的Activity跳轉代碼處添加判斷Secondary DEX是否加載完成?這個方法可行,但工作量非常大; 那有沒有更好的解決方案呢?我們通過分析Activity的啟動過程,發現Activity是由ActivityThread 通過Instrumentation來啟動的,我們是否可以在Instrumentation中做一定的手腳呢?通過分析代碼ActivityThread和Instrumentation發現,Instrumentation有關Activity啟動相關的方法大概有:execStartActivity、newActivity等等,這樣我們就可以在這些方法中添加代碼邏輯進行判斷這個Class是否加載了,如果加載則直接啟動這個Activity,如果沒有加載完成則啟動一個等待的Activity顯示給用戶,然后在這個Activity中等待后臺Secondary DEX加載完成,完成后自動跳轉到用戶實際要跳轉的Activity;這樣在代碼充分解耦合,以及每個業務代碼能夠做到顆粒化的前提下,我們就做到Secondary DEX的按需加載了, 下面是Instrumentation添加的部分關鍵代碼:

    public ActivityResult execStartActivity(Context who, IBinder contextThread, IBinder token, Activity target,Intent intent, int requestCode) {ActivityResult activityResult = null;String className;if (intent.getComponent() != null) {className = intent.getComponent().getClassName();} else {ResolveInfo resolveActivity = who.getPackageManager().resolveActivity(intent, 0);if (resolveActivity != null && resolveActivity.activityInfo != null) {className = resolveActivity.activityInfo.name;} else {className = null;}}if (!TextUtils.isEmpty(className)) {boolean shouldInterrupted = !MeituanApplication.isDexAvailable();if (MeituanApplication.sIsDexAvailable.get() || mByPassActivityClassNameList.contains(className)) {shouldInterrupted = false;}if (shouldInterrupted) {Intent interruptedIntent = new Intent(mContext, WaitingActivity.class);activityResult = execStartActivity(who, contextThread, token, target, interruptedIntent, requestCode);} else {activityResult = execStartActivity(who, contextThread, token, target, intent, requestCode);}} else {activityResult = execStartActivity(who, contextThread, token, target, intent, requestCode);}return activityResult;}public Activity newActivity(Class<?> clazz, Context context, IBinder token,Application application, Intent intent, ActivityInfo info,CharSequence title, Activity parent, String id, Object lastNonConfigurationInstance)throws InstantiationException, IllegalAccessException {String className = "";Activity newActivity = null;if (intent.getComponent() != null) {className = intent.getComponent().getClassName();}boolean shouldInterrupted = !MeituanApplication.isDexAvailable();if (MeituanApplication.sIsDexAvailable.get() || mByPassActivityClassNameList.contains(className)) {shouldInterrupted = false;}if (shouldInterrupted) {intent = new Intent(mContext, WaitingActivity.class);newActivity = mBase.newActivity(clazz, context, token,application, intent, info, title, parent, id,lastNonConfigurationInstance);} else {newActivity = mBase.newActivity(clazz, context, token,application, intent, info, title, parent, id,lastNonConfigurationInstance);}return newActivity;}

    實際應用中我們還遇到另外一個比較棘手的問題, 就是Field的過多的問題,Field過多是由我們目前采用的代碼組織結構引入的,我們為了方便多業務線、多團隊并發協作的情況下開發,我們采用的aar的方式進行開發,并同時在aar依賴鏈的最底層引入了一個通用業務aar,而這個通用業務aar中包含了很多資源,而ADT14以及更高的版本中對Library資源處理時,Library的R資源不再是static final的了,詳情請查看google官方說明,這樣在最終打包時Library中的R沒法做到內聯,這樣帶來了R field過多的情況,導致需要拆分多個Secondary DEX,為了解決這個問題我們采用的是在打包過程中利用腳本把Libray中R field(例如ID、Layout、Drawable等)的引用替換成常量,然后刪去Library中R.class中的相應Field。

    總結

    上面就是我們在使用MultiDex過程中進化而來的DEX自動化拆包的方案, 這樣我們就可以通過腳本控制來進行自動化的拆分DEX,然后在運行時自由的加載Secondary DEX,既能保證冷啟動速度,又能減少運行時的內存占用。


    原文地址: http://tech.meituan.com/mt-android-auto-split-dex.html

    總結

    以上是生活随笔為你收集整理的美团Android DEX自动拆包及动态加载简介的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    欧美一二三区播放 | 日韩最新在线 | 91av在线视频播放 | 日韩成人在线一区二区 | 九九九国产 | 亚洲理论在线 | 国产91av视频在线观看 | 欧美三级在线播放 | 国产不卡免费 | 日韩大片在线免费观看 | 最近高清中文字幕 | 亚洲四虎 | 日韩激情第一页 | 日韩av在线小说 | 色天天中文 | 日日激情| 成人一区二区三区在线观看 | 精品中文字幕在线播放 | 精品国产欧美一区二区 | 成人黄色在线观看视频 | 在线观看爱爱视频 | 不卡的av电影在线观看 | 日韩在线视频精品 | 免费高清男女打扑克视频 | 国产a国产a国产a | 午夜影院先 | 久久欧美综合 | 国产高清视频在线观看 | 91九色视频 | 婷婷去俺也去六月色 | 超碰公开97 | 久久精品美女视频 | 午夜在线看 | av成人动漫在线观看 | 2019av在线视频| 日韩黄视频| 成人国产精品电影 | 国产午夜三级一区二区三桃花影视 | 日日摸日日添日日躁av | 久久这里只有精品视频首页 | 天天夜夜操 | 超碰公开在线 | 精品国产成人在线影院 | 久久99免费视频 | av最新资源| 国产a级精品| 婷婷丁香七月 | 日韩中文字幕91 | 草久在线 | 久久久久国产一区二区三区四区 | 日韩偷拍精品 | 日韩在线视 | 99久久精| 欧美日韩在线观看一区二区三区 | 丰满少妇在线观看资源站 | 久久一精品 | 中文字幕有码在线 | 欧美一二三在线 | 国产高清在线视频 | www.天天草 | 天堂av网址 | www.狠狠操| 国产综合精品一区二区三区 | 免费福利片 | 天堂av高清| 国产999在线| 日av免费 | 国产福利一区二区在线 | 91在线视频精品 | 97超碰资源总站 | 久久免费在线观看视频 | 亚洲国产精品va在线看 | 国产极品尤物在线 | 亚洲日本va在线观看 | 日日爱av | 日韩av免费观看网站 | 中文不卡视频在线 | 国产 亚洲 欧美 在线 | 在线观看欧美成人 | 久久人操 | 免费精品在线 | 成人h在线| 超碰免费在线公开 | 国产亚洲午夜高清国产拍精品 | 国产极品尤物在线 | 人人添人人 | 五月天欧美精品 | 超碰97人人射妻 | 日夜夜精品视频 | 国产3p视频| 亚洲va在线va天堂va偷拍 | 久精品在线 | 免费观看av | 看国产黄色片 | 亚洲91中文字幕无线码三区 | 国产不卡视频在线播放 | 婷婷综合成人 | 六月丁香激情网 | av官网在线 | 欧美激情va永久在线播放 | 亚洲黄色激情小说 | 天天艹天天| 91大神电影 | 欧美精品v国产精品 | 九九热精品国产 | 国产麻豆精品传媒av国产下载 | 久久99国产精品久久99 | 天天干天天操天天搞 | 亚洲高清在线精品 | 在线视频99 | 日韩精品资源 | 婷婷五综合 | 999视频在线播放 | 99精品视频在线观看播放 | 久久99精品国产99久久6尤 | 91看片在线看片 | 在线视频app | 99综合电影在线视频 | 四虎影视4hu4虎成人 | 91精品视频在线 | 日韩免费在线视频观看 | 国产精品一区专区欧美日韩 | 精品美女在线观看 | 中国一级片在线观看 | 视频在线观看入口黄最新永久免费国产 | 国产亲近乱来精品 | 黄色av一区二区三区 | 日本成人中文字幕在线观看 | 久久成人综合 | 国产精华国产精品 | 精品国产a | 91完整视频 | 国产系列 在线观看 | 日韩成人在线免费观看 | 97福利在线 | 在线观看中文字幕第一页 | 色是在线视频 | 国产成人精品aaa | 91精品一区二区三区久久久久久 | 一本一本久久a久久精品综合 | 精品视频久久 | 欧美日韩一区二区在线观看 | 免费看黄电影 | 伊人超碰在线 | 日韩一区正在播放 | 激情视频久久 | 天天色图 | 香蕉精品在线观看 | 成人a级黄色片 | 国产日产精品一区二区三区四区的观看方式 | www日韩高清| 久久99在线视频 | 最新免费中文字幕 | 成人免费视频播放 | 丁香5月婷婷久久 | 自拍超碰在线 | 国产一级片久久 | 96精品视频| 国产无遮挡又黄又爽在线观看 | 国产精品涩涩屋www在线观看 | 福利片视频区 | 精品国产一区二区三区久久久蜜月 | 美女视频一区二区 | 中文字幕在线播出 | 99riav1国产精品视频 | 韩国精品一区二区三区六区色诱 | 人人看人人爱 | 久久久久99999 | 国产一级不卡视频 | 在线看一区 | 久久久精品国产一区二区电影四季 | 久草在线最新免费 | 成人免费在线视频观看 | 亚洲不卡av一区二区三区 | 久久婷婷精品 | 超碰在线中文字幕 | 久久精品日产第一区二区三区乱码 | 国产一级视频免费看 | 中文字幕频道 | 一性一交视频 | 久久久久国产一区二区三区 | 久久精品视频在线播放 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 欧美午夜视频在线 | 国产999精品久久久 免费a网站 | 久久人人插 | 91激情在线视频 | 国产亚洲精品久久久久久电影 | 毛片精品免费在线观看 | 在线观看日韩中文字幕 | 中文字幕在线观看av | 色偷偷中文字幕 | av电影一区二区三区 | 国产女v资源在线观看 | 精品一二区| 国产免费观看久久黄 | 日本精品一区二区在线观看 | 中文av影院 | 久久久久观看 | 久久久久久久久久影院 | 久久精品成人欧美大片古装 | 精品久久久影院 | 国产在线最新 | 日韩大片在线观看 | 在线中文视频 | 欧美不卡视频在线 | 美国三级黄色大片 | 香蕉视频日本 | 国产高清在线观看av | 成人久久视频 | 国产做aⅴ在线视频播放 | 日韩精品专区在线影院重磅 | 尤物九九久久国产精品的分类 | 青青草国产成人99久久 | 经典三级一区 | 国产精品久99 | 国产亚洲精品久久久久动 | 天海冀一区二区三区 | 久久人人爽爽人人爽人人片av | 激情五月婷婷综合网 | 国产日韩视频在线观看 | 一区二区三区动漫 | 久久久高清视频 | 中文字幕在线观看日本 | 天堂网av在线 | 国产精品久久久久久久久大全 | 免费国产黄线在线观看视频 | 在线香蕉视频 | 国产小视频福利在线 | 久草在| 免费91麻豆精品国产自产在线观看 | 日韩综合一区二区三区 | 青青河边草观看完整版高清 | 日韩簧片在线观看 | 五月婷香 | 在线免费观看黄色小说 | 国产一区二区三区在线 | 伊人天堂久久 | 国产色婷婷 | 亚洲激情校园春色 | 天天干夜夜夜操天 | 国产91探花| 天天射天天射天天 | 国内精品国产三级国产aⅴ久 | 狠狠狠狠狠狠天天爱 | 一区二区在线电影 | 丁香花在线观看视频在线 | 亚洲砖区区免费 | 香蕉视频久久久 | 亚洲精品美女久久 | 国产精品黄色 | www.色就是色 | 四虎在线免费观看 | 亚洲在线综合 | 免费视频99| 欧美另类重口 | 国产在线精品国自产拍影院 | 久久婷婷一区二区三区 | 91视频在线| 9草在线| 欧美一区二区三区四区夜夜大片 | 国内精品久久久久影院男同志 | 精品一二三四视频 | 国产精品久久久久影院 | 97精品久久人人爽人人爽 | 热99在线 | 天天射综合网视频 | 在线看一区| 久久久久久久久毛片 | 日韩亚洲国产精品 | 91在线看黄 | 麻豆首页 | 久久久91精品国产一区二区三区 | 国产精品乱码久久 | 亚洲久久视频 | 在线91观看 | 一区二区三区免费在线播放 | 亚洲免费在线看 | 日韩在线在线 | 国产一级在线免费观看 | 欧美91av| 伊人婷婷综合 | 国产视频一区二区在线 | 日韩午夜在线观看 | 久久伊人五月天 | 黄a网站 | 天天干国产 | 97热视频 | 狠狠干干 | www狠狠操 | 日韩欧美综合在线视频 | 不卡中文字幕在线 | 中文字幕在线免费 | 亚洲精品一区二区网址 | 国产一区黄色 | 欧美99热| 亚洲国产日韩欧美 | 91免费版在线观看 | 欧美亚洲xxx | 综合网婷婷 | 亚洲毛片视频 | 狠狠久久婷婷 | 国产精品视频久久久 | 国产中文字幕大全 | 国产剧情在线一区 | 国产精品麻豆免费版 | 国产一二三四在线观看视频 | 国产特级毛片aaaaaa毛片 | 网站在线观看你们懂的 | 日本最大色倩网站www | 久久毛片网站 | av在线激情 | 97精产国品一二三产区在线 | 色网站在线观看 | 91香蕉视频在线 | 韩国av一区二区三区在线观看 | 在线免费视频 你懂得 | 国产成人亚洲精品自产在线 | 国产91欧美 | 精品美女在线视频 | 91超国产| 亚洲黄色一级视频 | 色悠悠久久综合 | 亚洲国产婷婷 | 99色精品视频 | 日日夜夜精品免费观看 | 免费日韩一区 | 在线观看aa | 国产综合在线视频 | av超碰在线 | 射久久久 | 欧美日韩一区二区三区视频 | 欧美午夜精品久久久久 | 亚洲成av人影片在线观看 | 最近日本中文字幕 | www视频在线播放 | 国产色女 | 欧美日产一区 | 91精品在线视频观看 | 92精品国产成人观看免费 | 91大神电影 | 国产一级做a | 欧美一级片播放 | 亚洲自拍偷拍色图 | 欧美日韩国产二区 | 在线免费av网| 国产日韩欧美视频在线观看 | 国产在线观看污片 | 天天干天天草 | 午夜视频在线瓜伦 | 亚洲黄色三级 | 亚洲精品网页 | 免费av一级电影 | 久久国语露脸国产精品电影 | 视频一区二区在线 | 激情影音 | 在线观看免费成人 | 草久电影 | 亚洲www天堂com | 在线天堂中文在线资源网 | 日本在线观看一区二区三区 | 久久中文字幕在线视频 | 久草在线精品观看 | 在线免费观看视频a | 欧洲不卡av| 天天爽天天做 | 久久精品中文 | 尤物一区二区三区 | 91精品国| 黄色免费网站 | 天天草天天干天天射 | 胖bbbb搡bbbb擦bbbb | 视频在线观看国产 | 精品美女在线视频 | 亚洲精品视频在线观看免费视频 | 亚洲国内精品视频 | 亚洲成人一二三 | 久草在线在线视频 | 久久久久网站 | 黄色片软件网站 | 狠狠操精品 | 国产精品毛片一区视频播 | 午夜视频在线观看网站 | 亚洲精品在线国产 | 99热国产在线中文 | 亚洲精品在线二区 | 亚洲精欧美一区二区精品 | 国语对白少妇爽91 | 天天射天天舔天天干 | 国产精品久久99综合免费观看尤物 | 亚洲年轻女教师毛茸茸 | 999免费视频 | av在线播放免费 | 在线小视频 | 西西大胆啪啪 | 人人干人人干人人干 | 国内亚洲精品 | 亚洲欧洲国产视频 | 国产成人精品一区二区三区福利 | 久久香蕉国产精品麻豆粉嫩av | 婷婷免费在线视频 | 99精品久久久久 | 激情狠狠干 | 91亚色视频在线观看 | 三级在线视频观看 | 丁香六月婷婷激情 | 成人av日韩| 黄色毛片在线看 | 最近的中文字幕大全免费版 | 中文字幕在线免费播放 | 欧美成人视 | 中文字幕亚洲欧美日韩 | 国产成人精品国内自产拍免费看 | 亚洲精品在线视频观看 | 97超碰国产在线 | 一本一道久久a久久综合蜜桃 | 99中文在线| 日韩欧美精品一区二区三区经典 | 日躁夜躁狠狠躁2001 | www.国产视频 | 天天射天天射天天射 | 国产精品免费不 | 久草免费在线观看 | 黄色免费观看视频 | av 一区二区三区四区 | 亚洲国产精品久久久 | 在线www色| 999在线精品 | 99久久精品久久久久久动态片 | 欧美成人tv | 久久69av | 伊人永久在线 | 欧美日韩一区二区三区不卡 | 欧美色伊人 | 国内视频 | 在线观看亚洲免费视频 | 日本久久久久久久久 | 欧美视频一区二 | 国产手机精品视频 | 99999精品视频 | 日韩理论 | 亚洲aⅴ在线观看 | 高清视频一区 | 五月天综合网站 | 亚洲欧美国产视频 | 亚洲精品综合在线观看 | 亚洲在线视频免费 | 午夜婷婷综合 | av免费线看 | 日韩精品免费在线视频 | 久久国产热视频 | 久久国产精品免费看 | 狠狠色丁香婷婷 | 亚洲精品美女免费 | 在线观看中文字幕第一页 | 高清有码中文字幕 | www.99av| 99热.com| 国产精品一区二区久久久久 | 麻豆一区在线观看 | 一级大片在线观看 | 国产精品密入口果冻 | 人人干干人人 | 97色se| 最近中文字幕免费av | 国产精品18videosex性欧美 | 欧美日韩啪啪 | 亚洲成人欧美 | 99精品国产99久久久久久福利 | 在线精品视频免费播放 | 一区二区三区免费在线观看视频 | 免费观看黄色av | 2019免费中文字幕 | 成人 亚洲 欧美 | 久久手机免费视频 | 国产不卡免费 | 色噜噜日韩精品欧美一区二区 | 久久综合久久八八 | 成人免费观看视频大全 | 国产黄在线 | 四虎成人精品永久免费av | 三上悠亚在线免费 | 在线日本v二区不卡 | 91福利社区在线观看 | 6080yy午夜一二三区久久 | 6080yy午夜一二三区久久 | 国产91在线看| 国产精品一区二区久久久 | 亚洲免费资源 | 国产中年夫妇高潮精品视频 | sm免费xx网站 | 97夜夜澡人人双人人人喊 | 久久午夜免费观看 | 国产精品美女久久久久久久网站 | 亚洲女裸体 | 一区二区三区国产欧美 | 天天干天天射天天爽 | 日日爽夜夜操 | 免费在线观看亚洲视频 | 91亚色免费视频 | 久99久中文字幕在线 | 91精品秘密在线观看 | 亚洲人成影院在线 | 亚洲精品免费在线观看视频 | 天天综合视频在线观看 | 亚洲免费公开视频 | 久久视频在线观看中文字幕 | 国产高清 不卡 | 97人人澡人人爽人人模亚洲 | 日韩视频一区二区三区在线播放免费观看 | 欧美最猛性xxxxx(亚洲精品) | 曰本免费av | 久久日韩精品 | 国产精品美女久久久久久久久 | 国产精品美女久久久久久2018 | 一区二区三区免费在线 | 国产伦理精品一区二区 | 国产精品扒开做爽爽的视频 | 国产亚洲精品久久久久久大师 | av成人在线看 | 国产美女网 | 久久久久久久久久伊人 | 亚洲aⅴ久久精品 | 天天婷婷| 日韩午夜av | av福利在线免费观看 | 久久av中文字幕片 | 国产精品福利久久久 | 久久网站最新地址 | 日韩视频免费观看高清 | 国产在线色视频 | www.黄色| 中文字幕乱偷在线 | 在线观看成人一级片 | 日本高清中文字幕有码在线 | 国产精品久久网 | 亚洲成av人影院 | 91av在线免费 | 亚洲成免费 | av中文字幕在线看 | 人人插人人澡 | 亚洲国产成人在线播放 | 99国产情侣在线播放 | 亚洲永久精品国产 | 欧洲色吧 | 五月婷婷综合在线视频 | 在线a视频 | 久久久视屏 | 久久久精品免费观看 | 伊人春色电影网 | 欧美久久久久久久久久久久久 | 伊甸园永久入口www 99热 精品在线 | 日韩免费观看高清 | 美女视频黄是免费的 | 国产亚洲欧洲 | av片在线看| 欧美成人理伦片 | 欧美在线视频一区二区 | 91成年人在线观看 | 精品久久久久国产免费第一页 | 97色视频在线 | 看黄色91| 丁香九月激情综合 | 日韩成人免费电影 | 亚洲精品97 | 美女网色| 欧洲av不卡| 国产亚州av | 久久久婷 | 草在线视频 | 久久成人国产精品一区二区 | 干干干操操操 | 亚洲国产字幕 | 国产香蕉久久精品综合网 | 91久久国产露脸精品国产闺蜜 | 综合网av| 久热av| 精品国产一区二区三区久久 | 免费看国产一级片 | 久久一二区 | 欧美日韩国产伦理 | 中文字幕一区二区在线观看 | www.亚洲激情.com | 在线免费观看亚洲视频 | 久久av网址 | 99色亚洲| 激情欧美xxxx | 中文字幕在线不卡国产视频 | 国产精品综合久久久久久 | 久久久久久久免费 | 亚洲综合日韩在线 | 欧美一级专区免费大片 | www黄色软件 | 高清av在线免费观看 | 久久99视频免费 | 91精品网站在线观看 | 久草在线播放视频 | 99久久成人 | 韩国av免费观看 | 久久久久婷 | 激情综合亚洲 | 欧美成人在线免费 | 久久6精品 | 日日夜夜免费精品视频 | 国产精品综合在线观看 | 亚洲高清国产视频 | 91久久丝袜国产露脸动漫 | 国产无遮挡又黄又爽馒头漫画 | 在线观看岛国 | 波多野结衣日韩 | 日日夜夜天天 | 91黄色成人| 国产福利在线免费观看 | 中文国产字幕在线观看 | 亚洲自拍av在线 | 国产玖玖视频 | 成人免费在线网 | 国产视频高清 | 国产精品手机在线播放 | 丁香午夜婷婷 | 精品伊人久久久 | 久久这里只有精品9 | 欧美一区三区四区 | 成人黄色一级视频 | 亚洲国产精品久久久久婷婷884 | 亚洲精品456在线播放第一页 | 天天插综合网 | 国产精品 亚洲精品 | 欧美日韩视频在线播放 | 日本黄色免费播放 | 国产成人免费观看久久久 | 丁香婷婷深情五月亚洲 | 99精品系列 | 国产手机视频在线 | 国产经典三级 | 亚洲精品视频免费在线观看 | 在线视频你懂 | 99视频精品| 一区二区久久久久 | 国产精品电影一区二区 | 亚洲国产高清视频 | 免费欧美精品 | 欧美亚洲一级片 | 在线观看成人 | 911精品美国片911久久久 | 久视频在线| 欧美日韩精品在线一区二区 | 香蕉视频最新网址 | 欧美巨大荫蒂茸毛毛人妖 | 色综合天天综合在线视频 | 日日碰狠狠添天天爽超碰97久久 | 欧美一区二区精品在线 | 日韩最新在线视频 | 黄色亚洲片 | 狠狠干网 | 四虎影视成人精品国库在线观看 | 日韩电影久久久 | 国产在线2020 | 婷婷亚洲综合五月天小说 | 黄色特级片 | 国产一级久久 | 色wwwww| 日本中文字幕免费观看 | 亚洲mv大片欧洲mv大片免费 | 97视频成人 | 日本少妇视频 | 99精品视频播放 | 久久黄色片 | 久久人人添人人爽添人人88v | 国产精品久久久久久久久久白浆 | 激情av一区二区 | 精品国产伦一区二区三区免费 | 在线视频一区观看 | 最近中文字幕免费 | 中文字幕av网站 | 国产精品色 | 成片免费观看视频大全 | 中文字幕在线观看av | 婷婷免费在线视频 | 国产精品久久久久久久久毛片 | 99久久精品一区二区成人 | 国产日韩欧美在线观看 | 久久狠狠亚洲综合 | 97福利视频 | 国内成人精品视频 | 国产亚洲一区二区在线观看 | 中文在线a√在线 | 国产一线二线三线性视频 | 中文字幕一区三区 | 一级a毛片高清视频 | 国产精品久久久久久久久久久久 | 精品福利网 | 亚洲jizzjizz日本少妇 | 99草视频| 一区二区三区四区精品 | 一区二区不卡在线观看 | 日韩欧美在线不卡 | 99免费国产 | 最近日韩中文字幕中文 | 国产黄色在线看 | www.av免费| 婷婷色在线视频 | 午夜视频不卡 | 国产精品午夜在线 | 久久新视频| 亚洲欧洲中文日韩久久av乱码 | 波多野结衣一区二区 | 亚洲精品在线播放视频 | 国产主播大尺度精品福利免费 | 日韩精品视频在线观看免费 | 午夜精品久久久久久久99婷婷 | 亚洲最新av | 中文字幕视频在线播放 | 97成人在线 | 亚洲乱码中文字幕综合 | 91视频免费视频 | 波多野结衣视频一区二区 | 91精品久久久久久久久久久久久 | 狠狠色丁香婷婷综合久久片 | 亚洲每日更新 | 欧美一区成人 | 精品久久影院 | 久久99精品国产91久久来源 | 在线观看国产区 | 精品国产理论 | 成人欧美一区二区三区黑人麻豆 | 中文在线亚洲 | 奇米7777狠狠狠琪琪视频 | 青青草国产成人99久久 | 欧美精品久久久久久久久久久 | 欧美少妇的秘密 | 中文字幕 国产视频 | 91亚洲精品久久久蜜桃网站 | 日本特黄特色aaa大片免费 | 狠狠做深爱婷婷综合一区 | 在线观看视频一区二区 | 欧美日韩中文国产一区发布 | 69国产盗摄一区二区三区五区 | 中文av免费 | 成人一级视频在线观看 | 99久久精品网 | 午夜视频不卡 | 久久久99精品免费观看app | 一级电影免费在线观看 | 精品视频一区在线 | 国产黄a三级三级 | 美女黄色网在线播放 | 欧美日本一区 | 三级在线视频观看 | 国产在线高清精品 | 亚洲精品美女视频 | 99色在线视频 | 在线观看不卡视频 | www.亚洲激情.com | 精品视频一区在线观看 | 日本中文字幕在线 | 国产黄色播放 | 成人黄色在线视频 | 国产精品久久伊人 | 国产综合在线视频 | 国产精品麻 | 波多野结衣在线播放视频 | 99草视频 | 精品国产一区二区三区av性色 | 久久精品国产亚洲 | 国产又黄又爽无遮挡 | 婷婷亚洲五月 | 欧美最猛性xxx | 精品视频在线视频 | 在线国产一区二区 | 久久爱导航 | 午夜精品电影 | 日韩综合精品 | 91精品国产综合久久福利不卡 | 色香蕉网| 97视频在线观看网址 | 婷婷九九| 久久不射电影院 | 国产精品99久久久久久小说 | 93久久精品日日躁夜夜躁欧美 | 国产黄色片免费 | 日韩欧美视频二区 | 人人玩人人添人人澡超碰 | av中文天堂在线 | 国产永久免费高清在线观看视频 | 亚洲人毛片 | 激情久久久久久久久久久久久久久久 | 在线成人国产 | 午夜久久美女 | 国产一级电影在线 | 久久久久久免费视频 | 国产综合香蕉五月婷在线 | 深夜福利视频在线观看 | 久久久久免费电影 | 午夜精品久久久久久久久久 | 干av在线 | 国产精品麻豆91 | 国产精品美女久久久 | 国产粉嫩在线 | 粉嫩av一区二区三区四区五区 | 丁香婷婷综合激情 | 中文字幕4 | 国产三级国产精品国产专区50 | 亚洲欧美国产精品18p | 亚洲精品视频在线免费播放 | 精品久久网 | 91激情视频在线播放 | 成人免费网站在线观看 | 久久高清免费视频 | 最近中文字幕在线中文高清版 | 日韩精品在线免费播放 | 日韩视频在线观看免费 | avlulu久久精品 | 亚洲黄色免费网站 | 93久久精品日日躁夜夜躁欧美 | 成 人 黄 色视频免费播放 | 一区二区三区日韩视频在线观看 | 在线观看视频一区二区三区 | 国产视频一区二区在线 | 亚洲视频在线免费看 | 丁香电影小说免费视频观看 | www.av免费观看| 狠狠色丁香久久婷婷综合丁香 | 精品一区二区在线免费观看 | 日韩午夜视频在线观看 | 欧美精彩视频在线观看 | 啪啪动态视频 | 免费情缘 | 中文字幕丝袜制服 | 超碰伊人网 | 在线观看成人国产 | 久久久亚洲麻豆日韩精品一区三区 | 精品国产午夜 | 黄a网站 | 日韩av午夜在线观看 | 午夜视频日本 | 亚洲女同ⅹxx女同tv | 92精品国产成人观看免费 | 久久精品一级片 | 在线看成人片 | 亚洲一区二区黄色 | 国产视频 久久久 | 日韩精品一区二区免费 | 91porny九色91啦中文 | 一级做a视频 | 久久精品久久精品久久39 | aaa日本高清在线播放免费观看 | 一区二区丝袜 | 亚洲一区视频在线播放 | 西西4444www大胆视频 | 国产69久久久 | 狠狠操操 | 99热精品免费观看 | 国产免费观看久久 | 久久99国产精品视频 | 亚洲最大的av网站 | 久久福利在线 | 91视频91自拍 | 精品久久一级片 | 在线一区二区三区 | 色com网 | 欧美国产一区在线 | 在线观看国产一区二区 | 国产亚洲精品美女久久 | 91免费高清观看 | 亚洲黄色免费 | 九九热在线观看 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 日韩在线观看视频中文字幕 | 99热九九这里只有精品10 | 国产精品五月天 | 一区二区三区四区五区在线 | 日日躁夜夜躁aaaaxxxx | 日韩91av| 九九热视频在线播放 | 在线免费av网站 | 久久精品在线 | 亚洲欧美在线综合 | 婷婷综合在线 | 一级精品视频在线观看宜春院 | av字幕在线| 亚洲伦理中文字幕 | 综合色影院 | 久久玖| 99一级片 | 久久99婷婷 | 色综合久久中文综合久久牛 | 亚洲毛片视频 | 伊人一级 | 中文字幕 欧美性 | 91黄色在线看 | 久青草影院 | 精品福利网 | 精品av在线播放 | 激情综合婷婷 | 日韩高清dvd | 国产精品专区在线 | 国产片免费在线观看视频 | 国产成人精品免费在线观看 | 国产免费激情久久 | 欧美日韩裸体免费视频 | 美女视频黄免费的久久 | 国产最新视频在线观看 | 欧美日韩一区三区 | 亚洲精品合集 | 免费看一级黄色大全 | 国产区免费在线 | 99国内精品久久久久久久 | 国产亚洲激情视频在线 | 黄色三级av | 天天操天天摸天天爽 | 正在播放一区 | 97成人免费视频 | 欧美大jb| 亚洲精品综合在线 | 99热这里只有精品国产首页 | av中文字幕在线观看网站 | 国产艹b视频 | 久久有精品 | 久久久久免费精品国产 | 黄色不卡av | 日韩美精品视频 | 国产精品美女久久 | 久久福利 | 久久久av电影 | 日本久久久久久 | 在线观看片 | 在线播放精品一区二区三区 | 国产精品女同一区二区三区久久夜 | 四虎在线观看视频 | 一级淫片a| 网站免费黄 | 在线观看岛国av | 手机在线视频福利 | 久草免费在线 | 国产无套精品久久久久久 | 久久久91精品国产一区二区精品 | 在线观看成人毛片 | www.香蕉视频在线观看 | 天天操天天摸天天爽 | 国产精品网站 | 欧美另类调教 | 在线va视频 | 日韩在线观看第一页 | 美女久久一区 | 美女黄频在线观看 | 在线免费观看一区二区三区 | www天天操 | 国产成人精品免高潮在线观看 | 不卡精品视频 | ww视频在线观看 | 国产亚洲成av人片在线观看桃 | 婷婷综合av | 国产精品99免视看9 国产精品毛片一区视频 | 亚洲观看黄色网 | 欧美少妇xx | 欧美日韩精品在线一区二区 | 中文字幕av全部资源www中文字幕在线观看 | 成人9ⅰ免费影视网站 | 91av九色| 婷婷综合av| 黄污污网站 | a视频在线观看免费 | 成人在线视频网 | 在线视频一区观看 | 顶级欧美色妇4khd | 97超碰香蕉 | 中文字幕一区二区三区在线观看 | 少妇bbbb搡bbbb桶 | 亚洲综合爱 | 日本中文字幕免费观看 | 国产中文字幕一区二区三区 | 最新av网址大全 | 日日爽天天爽 | 国产午夜精品理论片在线 | 一区二区免费不卡在线 | 激情视频久久 | av福利超碰网站 | 在线观看成人毛片 | www毛片com| 在线 影视 一区 | 国产91全国探花系列在线播放 | 欧美久久影院 | 亚洲国产高清在线观看视频 | 黄色小视频在线观看免费 | 中文字幕超清在线免费 | 91av美女| 91av精品| 久久亚洲综合国产精品99麻豆的功能介绍 | 久久综合中文色婷婷 | 1区2区3区在线观看 三级动图 | 日本久久成人中文字幕电影 | 一本一本久久a久久精品综合 | 国产精品久久久久av免费 | 亚洲成人av电影 | 99热国产在线观看 | 久久久久久国产精品美女 | 亚洲美女视频在线 |