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

【寶貴經驗】Android性能優化之內存優化實戰

移動開發 Android
Android系統的每個進程都有一個最大內存限制,如果申請的內存資源超過這個限制,系統就會拋出OOM錯誤。內存溢出是程序運行到某一階段的最終結果,直接原因是剩余的內存不能滿足內存的申請。

1. Memory Leak

內存泄漏:對于Java來說,就是new出來的Object 放在Heap上無法被GC回收(內存中存在無法被回收的對象);內存泄漏發生時的主要表現為內存抖動,可用內存慢慢變少。

1.1 Memory Monitor

AndroidStudio自帶的Memory Monitor可以方便的觀察堆內存的分配情況,并且可以粗略的觀察有沒有Memory Leak。 

 

 

 

頻繁的內存抖動,可能存在內存泄漏

A:initiate GC 手動觸發GC操作;

B:Dump Java Heap 獲取當前的堆棧信息,生成一個.hprof文件,AndroidStudip會自動使用HeapViewer打開;一般用于操作之后檢測內存泄漏的情況;

C:Start Allocation Tracking 內存分配追蹤工具,用于追蹤一段時間的內存分配使用情況,能夠知道執行一些列操作后,有哪些對象被分配空間。一般用于追蹤某項操作之后的內存分配,調整相關的方法調用來優化app性能與內存使用;

D:剩余可用內存;

E:已經使用的內存。

點擊Memory Monitor的Dump Java Heap,會生成一個.hprof文件,AndroidStudio會自動使用HeapViewer打開。 

 

 

 

Hprof Viewer打開.hprof文件

左面板說明:

  • Total Count 該類的實例個數
  • Heap Count 選定的Heap中實例的個數
  • Sizeof 每個實例占用的內存大小
  • Shallow Size 所有該類的實例占用的內存大小
  • Retained Size 該類的所有實例可支配的內存大小

右面板說明:

  • Instance 該類的所有實例對象(左側Total Count為15,此處就有15個對象)
  • Depth 深度, GC Root點到該實例的最短鏈路數
  • Dominating Size 該實例可支配的內存大小

此處可以看出MainActivity存在了15個示例對象,懷疑此處有問題。

1.2 MAT

上述只是可以粗略的看出是不是有問題,而要知道問題出在哪里就需要借助MAT了。將生成的.hprof文件進行轉換,然后使用MAT打開;

格式轉換命令:hprof-conv 原文件路徑 轉換后文件路徑 

 

 

 

MAT打開.hprof

注意下面的Actions:

  • Histogram可以列出內存中每個對象的名字、數量以及大小。
  • Dominator Tree會將所有內存中的對象按大小進行排序,并且我們可以分析對象之間的引用結構。

一般使用最多的也是這兩個功能。

Retained Heap表示這個對象以及它所持有的其它引用(包括直接和間接)所占的總內存

  • 使用Histogram:
  • 點擊Histogram并在頂部的Regex中輸入MainActivity會進行正則匹配,會將包含“MainActivity”的所有對象全部列出了出來,其中***行就是MainActivity的實例。 

 

 

 

  • 對著想查看的對象點擊右鍵 -> List objects -> with incoming references 查看具體MainActivity實例。 

 

 

 

  • 對想要查看的對象實例點擊右鍵-> Path To Gc Roots -> exclude weak reference(排除掉軟引用)。 

 

 

 

注意:

this$0前面的圖標的左下角有個圓圈,這代表這個引用可以被Gc Roots引用到,由于MainActivity$LeakClass能被GC Roots訪問到導致其不能被回收,從而它所持有的其它引用也無法被回收了,包括MainActivity,也包括MainActivity中所包含的其它資源。

此時我們就找到了內存泄漏的原因。

  • 使用Dominator Tree 

 

 

 

使用上面Histogram的操作方式也可以找到泄漏的具體原因,此處不再累述。

注意:每個對象前的圖標的圓圈,并不代表一定是導致內存泄漏的原因,有些對象就是需要在內存中存活的,需要區別對待。

1.3 LeakCanary

LeakCanary是square出品的一個檢測內存泄漏的庫,集成到App之后便無需關心,在發生內存泄漏之后會Toast、通知欄彈出等方式提示,可以指出泄漏的引用路徑,而且可以抓取當前的堆棧信息供詳細分析。 

 

 

 

2. Out Of Memory

2.1 Android OOM

Android系統的每個進程都有一個***內存限制,如果申請的內存資源超過這個限制,系統就會拋出OOM錯誤。

  • Android 2.x系統,當dalvik allocated + external allocated + 新分配的大小 >= dalvik heap ***值時候就會發生OOM。其中bitmap是放于external中 。
  • Android 4.x系統,廢除了external的計數器,類似bitmap的分配改到dalvik的java heap中申請,只要allocated + 新分配的內存 >= dalvik heap ***值的時候就會發生OOM(art運行環境的統計規則還是和dalvik保持一致)

內存溢出是程序運行到某一階段的最終結果,直接原因是剩余的內存不能滿足內存的申請,但是再分析間接原因內存為什么沒有了:

  • 內存泄漏的存在可能導致可用內存越來越少;
  • 內存申請的峰值超過了系統時間點剩余的內存;(例如:某手機單個進程可用***內存為192M,目前分配內存80M,此時申請5M內存,但是當前時間點整個系統可用內存只有3M,此時沒有超出單個進程可用***內存,但是OOM也會發生)

2.2 Avoid Android OOM

除了避免內存泄漏之外,根據《Manage Your App's Memory》,我們可以對內存的狀態進行監聽,在Activity中覆寫此方法,根據不同的case進行不同的處理:

  1. @Override 
  2.     public void onTrimMemory(int level) {        super.onTrimMemory(level); 
  3.     }  

TRIM_MEMORY_RUNNING_MODERATE:你的應用正在運行并且不會被列為可殺死的。但是設備此時正運行于低內存狀態下,系統開始觸發殺死LRU Cache中的Process的機制。

TRIM_MEMORY_RUNNING_LOW:你的應用正在運行且沒有被列為可殺死的。但是設備正運行于更低內存的狀態下,你應該釋放不用的資源用來提升系統性能。

TRIM_MEMORY_RUNNING_CRITICAL:你的應用仍在運行,但是系統已經把LRU Cache中的大多數進程都已經殺死,因此你應該立即釋放所有非必須的資源。如果系統不能回收到足夠的RAM數量,系統將會清除所有的LRU緩存中的進程,并且開始殺死那些之前被認為不應該殺死的進程,例如那個包含了一個運行態Service的進程。

當應用進程退到后臺正在被Cached的時候,可能會接收到從onTrimMemory()中返回的下面的值之一:

TRIM_MEMORY_BACKGROUND: 系統正運行于低內存狀態并且你的進程正處于LRU緩存名單中最不容易殺掉的位置。盡管你的應用進程并不是處于被殺掉的高危險狀態,系統可能已經開始殺掉LRU緩存中的其他進程了。你應該釋放那些容易恢復的資源,以便于你的進程可以保留下來,這樣當用戶回退到你的應用的時候才能夠迅速恢復。

TRIM_MEMORY_MODERATE: 系統正運行于低內存狀態并且你的進程已經已經接近LRU名單的中部位置。如果系統開始變得更加內存緊張,你的進程是有可能被殺死的。

TRIM_MEMORY_COMPLETE: 系統正運行于低內存的狀態并且你的進程正處于LRU名單中最容易被殺掉的位置。你應該釋放任何不影響你的應用恢復狀態的資源。

3. Memory Churn

Memory Churn內存抖動:大量的對象被創建又在短時間內馬上被釋放。

瞬間產生大量的對象會嚴重占用Young Generation的內存區域,當達到閥值,剩余空間不夠的時候,也會觸發GC。系統花費在GC上的時間越多,進行界面繪制或流音頻處理的時間就越短。即使每次分配的對象占用了很少的內存,但是他們疊加在一起會增加Heap的壓力,從而觸發更多其他類型的GC。這個操作有可能會影響到幀率,并使得用戶感知到性能問題。 

 

 

 

Drop Frame Occur

常見的可能引發內存抖動的情形:

  • 循環中創建臨時對象;
  • onDraw中創建Paint或Bitmap對象等;

例如之前使用過的有些下拉刷新控件的實現方式,在onDraw中創建Bitmap等多個臨時大對象會導致內存抖動。

4. Bitmap

Bitmap的處理也是Android中的一個難點,當然使用第三方框架的話就屏蔽掉了這個難點。

  • Bitmap的內存模型;
  • Bitmap的加載、壓縮、緩存等策略;
  • 版本的兼容等;

關于Bitmap之后會寫專門的一篇文章來介紹,此處可以參考《Handling Bitmaps》。

5. Program Advice

5.1 節制地使用Service

內存管理***的錯誤之一就是讓Service一直運行。在后臺使用service時,除非它需要被觸發并執行一個任務,否則其他時候Service都應該是停止狀態。另外需要注意Service工作完畢之后需要被停止,以免造成內存泄漏。

系統會傾向于保留有Service所在的進程,這使得進程的運行代價很高,因為系統沒有辦法把Service所占用的RAM空間騰出來讓給其他組件,另外Service還不能被Paged out。這減少了系統能夠存放到LRU緩存當中的進程數量,它會影響應用之間的切換效率,甚至會導致系統內存使用不穩定,從而無法繼續保持住所有目前正在運行的service。

建議使用JobScheduler,而盡量避免使用持久性的Service。還有建議使用IntentService,它會在處理完交代給它的任務之后盡快結束自己。

5.2 使用優化過的集合

Android API當中提供了一些優化過后的數據集合工具類,如SparseArray,SparseBooleanArray,以及LongSparseArray等,使用這些API可以讓我們的程序更加高效。傳統Java API中提供的HashMap工具類會相對比較低效,因為它需要為每一個鍵值對都提供一個對象入口,而SparseArray就避免掉了基本數據類型轉換成對象數據類型的時間。

5.3 謹慎對待面向抽象

開發者經常把抽象作為好的編程實踐,因為抽象能夠提升代碼的靈活性與可維護性。然而,抽象會導致一個顯著的開銷:面向抽象需要額外的代碼(不會被執行到),同樣會被咨映射到內存中,耗費了更多的時間以及內存空間。因此如果面向抽象對你的代碼沒有顯著的收益,那你應該避免使用。

例如:使用枚舉通常會比使用靜態常量要消耗兩倍以上的內存,在Android開發當中我們應當盡可能地不使用枚舉。

5.4 使用nano protobufs序列化數據

Protocol buffers是Google為序列化數據設計的一種語言無關、平臺無關、具有良好擴展性的數據描述語言,與XML類似,但是更加輕量、快速、簡單。如果使用protobufs來實現數據的序列化及反序列化,建議在客戶端使用nano protobufs,因為通常的protobufs會生成冗余代碼,會導致可用內存減少,Apk體積變大,運行速度減慢。

5.5 避免內存抖動

垃圾回收通常不會影響應用的表現,但是短時間內多次的垃圾回收會消耗掉界面繪制的時間。系統花費在GC上的時間越多,進行界面繪制或流音頻處理的時間就越短。通常內存抖動會導致多次的GC,實踐中內存抖動代表了一段時間內分配了臨時對象。

例如:在For循環中分配了多個臨時對象,或在onDraw()方法中創建了Paint、Bitmap對象,應用產生了大量的對象;這會很快耗盡young generation的可用內存,導致GC發生。

使用Analyze your RAM usage中的工具找出代碼里內存抖動的地方。考慮把操作移出內部循環,或者將其移動到基于工廠的分配結構中。

5.6 移除消耗內存的庫、縮減Apk的大小

查看Apk的大小,包括三方庫和內嵌的資源,這些都會影響應用消耗的內存。通過減少冗余、非必須或大的組件、庫、圖片、資源、動畫等,都可以改善應用的內存消耗。

5.7 使用Dagger 2進行依賴注入

如果您打算在應用程序中使用依賴注入框架,請考慮使用Dagger 2。 Dagger不使用反射來掃描應用程序的代碼。 Dagger的編譯時注解技術實現意味著它不需要不必要的運行時成本。而使用反射的其它依賴注入框架通常通過掃描代碼來初始化過程。 此過程可能需要顯著更多的CPU周期和RAM,并可能導致應用程序啟動時明顯的卡頓。

備注:之前的文檔是不建議使用依賴注入框架,因為實現原理是使用反射,而進化為編譯時注解之后,就不再有反射帶來的影響了。

5.8 謹慎使用第三方庫

很多開源的library代碼都不是為移動端而編寫的,如果運用在移動設備上,并不一定適合。即使是針對Android而設計的library,也需要特別謹慎,特別是在你不知道引入的library具體做了什么事情的時候。例如,其中一個library使用的是nano protobufs, 而另外一個使用的是micro protobufs。這樣一來,在你的應用里面就有2種protobuf的實現方式。這樣類似的沖突還可能發生在輸出日志,加載圖片,緩存等等模塊里面。另外不要為了1個或者2個功能而導入整個library,如果沒有一個合適的庫與你的需求相吻合,你應該考慮自己去實現,而不是導入一個大而全的解決方案。

6. Other

6.1 謹慎使用LargeHeap屬性

可以通過在manifest的application標簽下添加largeHeap=true的屬性來為應用聲明一個更大的heap空間(可以通過getLargeMemoryClass()來獲取到這個更大的heap size閾值)。然而,聲明得到更大Heap閾值的本意是為了一小部分會消耗大量RAM的應用(例如一個大圖片的編輯應用)。不要輕易的因為你需要使用更多的內存而去請求一個大的Heap Size。只有當你清楚的知道哪里會使用大量的內存并且知道為什么這些內存必須被保留時才去使用large heap,使用額外的內存空間會影響系統整體的用戶體驗,并且會使得每次gc的運行時間更長。在任務切換時,系統的性能會大打折扣。另外, large heap并不一定能夠獲取到更大的heap。在某些有嚴格限制的機器上,large heap的大小和通常的heap size是一樣的。

6.2 謹慎使用多進程

多進程確實是一種可以幫助我們節省和管理內存的高級技巧。如果你要使用它的話一定要謹慎使用,因為絕大多數的應用程序都不應該在多個進程當中運行的,一旦使用不當,它甚至會增加額外的內存而不是幫我們節省內存;同時需要知曉多進程帶來的缺點。這個技巧比較適用于那些需要在后臺去完成一項獨立的任務,和前臺的功能是可以完全區分開的場景。

這里舉一個比較適合去使用多進程技巧的場景,比如說我們正在做一個音樂播放器軟件,其中播放音樂的功能應該是一個獨立的功能,它不需要和UI方面有任何關系,即使軟件已經關閉了也應該可以正常播放音樂。如果此時我們只使用一個進程,那么即使用戶關閉了軟件,已經完全由Service來控制音樂播放了,系統仍然會將許多UI方面的內存進行保留。在這種場景下就非常適合使用兩個進程,一個用于UI展示,另一個則用于在后臺持續地播放音樂。

6.3 實現方式可能存在的問題:例如啟動頁閃屏圖,show完畢之后應該釋放掉Bitmap。

一些實現方式看起來沒有問題實現了功能但是實際上可能對內存造成了影響。我在使用Heap Viewer查看Bitmap對象時發現了一張只需下載不應該被加載的圖。 

 

 

 

使用HeapViewer可直接查看Bitmap 

 

 

 

內存中出現的不應該被加載的圖

通過查閱代碼,發現問題出在:此處下載圖片作為另一個模塊的使用圖,但是下載的方法竟然是使用圖片加載器加載出來Bitmap然后再保存到本地;而且保存之后也沒有將Bitmap對象釋放掉。

與之類似的還有:首頁閃屏圖展示之后,Bitmap對象應該及時釋放掉。

6.4 使用try catch進行捕獲

對高風險OOM代碼塊如展示高清大圖等進行try catch,在catch塊加載非高清的圖片并做相應內存回收的處理。注意OOM是OutOfMemoryError,不能使用Exception進行捕獲。

7. Summary

內存優化的套路:

(1)解決所有的內存泄漏

  • 集成LeakCanary,可以方便的定位出90%的內存泄漏問題;
  • 通過反復進出可疑界面,觀察內存增減的情況,Dump Java Heap獲取當前堆棧信息使用MAT進行分析。
  • 內存泄漏的常見情形可參照《Android 內存泄漏分析心得》

(2)避免內存抖動

  • 避免在循環中創建臨時對象;
  • 避免在onDraw中創建Paint、Bitmap對象等。

(3)Bitmap的使用

  • 使用三方庫加載圖片一般不會出內存問題,但是需要注意圖片使用完畢的釋放,而不是被動等待釋放。
  • 使用優化過的數據結構
  • 使用onTrimMemory根據不同的內存狀態做相應處理

(4)Library的使用

  • 去掉無用的Library,對生成的Apk進行反編譯查看使用到的Library,避免出現無用的Lib仍然被打進Apk;
  • 避免引入巨大的Library;
  • 使用Proguard進行混淆、壓縮。
責任編輯:龐桂玉 來源: Android技術之家
相關推薦

2015-09-16 15:21:23

Android性能優化內存

2016-12-22 17:21:11

Android性能優化內存泄漏

2019-12-13 10:25:08

Android性能優化啟動優化

2010-07-06 16:22:14

2011-07-28 10:01:19

IOS 內存優化

2009-09-22 17:25:41

優化Hibernate

2009-04-20 08:51:50

MySQL查詢優化數據庫

2017-03-29 14:44:20

網絡性能優化

2022-05-17 09:02:30

前端性能優化

2011-06-20 13:35:01

網站優化

2010-02-23 16:17:59

2011-12-28 13:38:00

JavaJVM

2018-05-09 08:35:59

2012-01-10 16:22:25

Web

2009-12-16 15:23:33

Ruby on rai

2009-12-24 16:46:03

WPF性能優化

2021-07-29 14:20:34

網絡優化移動互聯網數據存儲

2019-07-25 13:22:43

AndroidAPK文件優化

2013-09-16 15:16:20

Android性能優化

2015-05-30 10:04:24

線下公開課51CTO沙龍MDSA
點贊
收藏

51CTO技術棧公眾號

日韩在线观看免费| 久久综合色8888| 久久精品亚洲精品| 中文字幕国产高清| 在线不卡日本v二区707| 成人动漫一区二区三区| 日本电影亚洲天堂| 三级全黄做爰视频| 高清日韩中文字幕| 91久久精品网| 大地资源网在线观看免费官网 | 一区二区三区高清在线| 国产免费一区二区| 探花国产精品一区二区| 欧美在线观看天堂一区二区三区| 精品国产成人系列| 精品无码国产一区二区三区av| 天堂中文资源在线| 麻豆精品蜜桃视频网站| 97国产精品视频| 国产精品一区二区亚洲| 精品在线网站观看| 欧美疯狂性受xxxxx喷水图片| 久操手机在线视频| av在线首页| 成人黄页在线观看| 91视频国产精品| 无码任你躁久久久久久久| 国产大片一区| 亚洲精品少妇网址| 久久久久久久久久久影视| 欧美性理论片在线观看片免费| 亚洲综合无码一区二区| 视频一区视频二区视频| 人妻妺妺窝人体色www聚色窝| 免费观看成人av| 久久久久久尹人网香蕉| 日韩av手机在线免费观看| 亚洲理论电影| 亚洲成人亚洲激情| 在线观看日本www| 国产 日韩 欧美一区| 亚洲福利视频导航| 樱空桃在线播放| 国产日韩精品在线看| 成人av动漫在线| 51国产成人精品午夜福中文下载| 中文字幕 国产精品| 亚洲精品美女91| 欧美激情精品久久久久久蜜臀 | 久久狠狠久久| 欧美videos中文字幕| 999久久久精品视频| 在线成人视屏| 色婷婷综合视频在线观看| 国产av国片精品| 日韩123区| 亚洲男同1069视频| av不卡在线免费观看| av色图一区| 亚洲国产成人私人影院tom| 日本一区精品| 国产视频二区在线观看| 国产欧美va欧美不卡在线| 欧美日韩一区二区三区在线视频| 午夜视频在线播放| 99久久精品国产网站| 成人在线观看91| 国产黄色片av| 国产一区二区成人久久免费影院 | 三级视频在线观看| 99国产一区| 欧美在线性爱视频 | 欧美日韩在线播放| 精品亚洲一区二区三区四区| 黄页免费欧美| 91精品国产入口在线| 99re6在线观看| 国产电影一区| 日韩欧美区一区二| 国偷自产av一区二区三区麻豆| 欧美.com| 亚洲国产一区二区三区在线观看| 中文字幕精品视频在线| 免费视频亚洲| 精品久久国产精品| 久久久国产精华液| 99热这里只有成人精品国产| 日韩av电影院| 一级黄色短视频| 国产福利一区二区三区在线视频| 国产福利一区二区三区在线观看| 天堂在线一二区| 国产欧美一区二区三区在线老狼| 在线日韩av永久免费观看| 色黄网站在线观看| 精品人伦一区二区三区蜜桃免费| 日本成人在线免费视频| 婷婷激情一区| 欧美日韩在线直播| 韩国三级视频在线观看| 国产一区二区三区天码| 久久在线视频在线| 在线观看免费国产视频| 免费成人在线观看视频| 懂色中文一区二区三区在线视频| 天天干视频在线观看| 中文字幕中文在线不卡住| 九色自拍视频在线观看| 成人精品一区二区三区电影| 日韩欧美在线综合网| 玖玖爱在线观看| 一区二区三区毛片免费| 美女精品视频一区| 亚洲一级电影视频| 国产日韩欧美在线观看| 亚洲AV无码一区二区三区少妇| 大胆亚洲人体视频| 欧美一区观看| 国产精品一卡二卡三卡| 欧美性感美女h网站在线观看免费| 国产成人黄色网址| av动漫精品一区二区| 尤物九九久久国产精品的分类| 欧美成人黄色网| 日韩和欧美一区二区| 国产激情美女久久久久久吹潮| 最新国产在线观看| 欧美视频一二三| 精品国产乱码久久久久夜深人妻| 俺要去色综合狠狠| 91av成人在线| 精品人妻无码一区二区三区蜜桃一| 26uuu国产一区二区三区| 四虎4hu永久免费入口| 日韩av福利| 日韩欧美自拍偷拍| 日本精品久久久久中文| 日韩午夜在线| 国产精品一 二 三| 亚洲男人的天堂在线视频| 少妇高潮av久久久久久| 91精品国产91久久久久久密臀 | 国产精品区一区二区三在线播放| 日韩精品成人av| 精品久久香蕉国产线看观看gif| 污网站在线免费| 菠萝蜜一区二区| 日韩av片免费在线观看| 少妇一区二区三区四区| 亚洲人成影院在线观看| 永久免费的av网站| 欧美色蜜桃97| 国产91色在线播放| 四虎影视精品成人| 欧美日韩精品二区| 日韩成人av一区二区| 亚洲午夜久久久久久尤物 | 9l亚洲国产成人精品一区二三 | 久久精品日韩欧美| 成人激情直播| 久久日韩视频| 欧美精品777| 日本黄色录像视频| 免费看日韩精品| 亚洲精品一区二区毛豆| 国产69精品久久久久按摩| 中文字幕日韩综合av| 91丨九色丨丰满| 亚洲精品免费在线播放| 麻豆传媒在线看| 欧美日韩亚洲一区| 国产欧美在线一区二区| 理论片午夜视频在线观看| 日韩丝袜情趣美女图片| 国产精品老熟女一区二区| 经典一区二区三区| 成人毛片100部免费看| av在线亚洲色图| 5278欧美一区二区三区| 国产毛片av在线| 欧美日本精品一区二区三区| 欧美性生交大片| 国产suv精品一区二区883| 欧美 日韩 亚洲 一区| 日韩欧美黄色| 国产精品久久久久久婷婷天堂| 国产原创视频在线观看| 精品国产三级a在线观看| 天天综合天天干| 国产欧美日韩综合精品一区二区| 天堂av在线网站| 一区二区三区四区电影| 久久久久一区二区| 成人不卡视频| 欧美极品欧美精品欧美视频 | 日韩国产高清视频在线| 亚洲无码精品一区二区三区| 亚洲丝袜美腿综合| 久久久午夜精品福利内容| 人人精品人人爱| 欧美成人精品免费| av亚洲免费| 国产高清不卡av| av成人在线播放| 欧美精品电影免费在线观看| 免费在线观看一级毛片| 日韩一级精品视频在线观看| 国产精品自拍99| 国产精品二三区| www男人天堂| 久久精品国产久精国产爱| 日韩国产一级片| 久久激情电影| 精品国产免费一区二区三区 | 欧美体内谢she精2性欧美| 亚洲AV成人无码网站天堂久久| av在线不卡免费看| 女人高潮一级片| 媚黑女一区二区| 国产精品www在线观看| 亚洲综合小说图片| 99视频免费观看蜜桃视频| 自拍一区在线观看| 久久精品美女视频网站| 国产福利在线视频| 日韩理论片久久| 亚洲精品911| 欧美人伦禁忌dvd放荡欲情| 中文字幕69页| 欧美日韩精品在线| 黄网站免费在线| 亚洲欧洲色图综合| 人成免费在线视频| 2021国产精品久久精品| 国产a级片视频| 国产一区不卡在线| 在线观看免费的av| 好看不卡的中文字幕| 中文字幕乱码免费| 欧美hd在线| 欧美日韩综合网| 亚洲不卡视频| www 成人av com| 亚洲国产中文在线| 亚洲伊人久久大香线蕉av| 日韩免费大片| 成人国产精品一区| 精品女同一区二区三区在线观看| 国产精品99蜜臀久久不卡二区| 在线高清av| 日韩免费高清在线观看| 欧美大片免费| 日本成人免费在线| 毛片无码国产| 国产成人精品电影久久久| 男人天堂亚洲天堂| 国产69精品久久久| 调教一区二区| 国内精品一区二区三区四区| 3344国产永久在线观看视频| 国语自产精品视频在免费| 99热99re6国产在线播放| 91精品国产色综合| 樱桃视频成人在线观看| 青青草精品毛片| 三上悠亚国产精品一区二区三区| 国产极品jizzhd欧美| jvid一区二区三区| 91九色在线视频| 欧美成年网站| 国产精品亚洲综合| 亚洲高清极品| 亚洲日本理论电影| 欧美一区激情| 欧美a级黄色大片| 好吊视频一区二区三区四区| 国产免费毛卡片| 亚洲尤物影院| 亚洲三级视频网站| 韩国三级在线一区| 日韩欧美色视频| 99久久免费精品高清特色大片| 免费观看av网站| 亚洲欧美自拍偷拍| 久久久久99精品| 日本道在线观看一区二区| 国产又爽又黄又嫩又猛又粗| 精品日韩99亚洲| 男同在线观看| 日韩视频精品在线| ****av在线网毛片| 国产精品永久免费观看| 色播一区二区| 欧美日韩国产综合视频在线| 忘忧草精品久久久久久久高清| 欧美亚洲黄色片| 喷白浆一区二区| 韩国一区二区在线播放| 99这里都是精品| 亚洲熟妇无码av| 亚洲日本护士毛茸茸| 五月激情六月丁香| 日韩一级黄色大片| 欧美少妇另类| 色综合久综合久久综合久鬼88| 台湾佬成人网| 肥熟一91porny丨九色丨| 伊人成综合网伊人222| 2021狠狠干| 久久一综合视频| 国产人妖在线观看| 中文字幕免费在线观看视频一区| 精国产品一区二区三区a片| 91久久精品一区二区二区| 亚洲h视频在线观看| 最新中文字幕亚洲| 亚洲高清黄色| 国产精品自拍首页| 亚洲精品一区二区在线看| 成年人观看网站| 激情五月播播久久久精品| a视频免费观看| 国产精品色哟哟网站| 精品91久久久| 欧美一区二区三区在线观看视频| 国产黄在线看| 91精品国产91久久| 麻豆视频久久| 亚洲国产精品一区二区第一页| 国产日韩亚洲欧美精品| 性生活在线视频| 中文字幕一区免费在线观看| 国产伦精品一区二区三区视频网站| 精品国产伦一区二区三区观看体验| 伦理片一区二区三区| 欧美乱妇高清无乱码| 四虎视频在线精品免费网址| 日本一区二区视频| 男女精品视频| 中文人妻一区二区三区| 亚洲成人在线网站| 超碰免费在线97| 久久精品国产一区二区电影| japanese23hdxxxx日韩| 国产九色精品| 欧美激情四色| 999热精品视频| 中文字幕一区二区在线播放 | 全色精品综合影院| 久久久亚洲成人| 国产精品极品| 水蜜桃色314在线观看| 成人天堂资源www在线| 男女免费视频网站| 精品人在线二区三区| 日本三级在线观看网站| av成人综合网| 红桃视频国产一区| 人人爽人人爽av| 亚洲欧美日本在线| 中文字幕精品无码亚| 中文字幕九色91在线| 日本午夜精品久久久久| 亚洲欧美精品| 韩国av一区二区三区| 欧美黑人性猛交xxx| 精品国产免费视频| 国产v日韩v欧美v| 免费国产一区| 日韩不卡一二三区| 成人自拍小视频| 欧美一卡二卡三卡四卡| 波多一区二区| 天堂一区二区三区| 国产精品夜夜爽| 天堂中文在线网| 色老头一区二区三区| 亚洲精品午夜| 久热免费在线观看| 亚洲欧美日韩久久精品| 四虎在线视频免费观看| 国产精品入口夜色视频大尺度 | 成人午夜激情av| 亚洲精品v日韩精品| 欧美日韩国产综合视频| 91在线视频导航| 国产日韩欧美一区在线| 日本午夜在线观看| 亚洲欧美制服第一页| 美女精品久久| 中文字幕欧美人妻精品一区| 一区二区视频免费在线观看| 国产三级电影在线| 国产高清自拍一区| 精品中文字幕一区二区小辣椒| 日韩av在线播放观看| www.欧美免费| 国产剧情在线观看一区| 少妇丰满尤物大尺度写真|