久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

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

编程问答

201509281125_《为什么移动app会很慢的深度分析(摘自司徒正美博客园文章)》

發布時間:2024/1/8 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 201509281125_《为什么移动app会很慢的深度分析(摘自司徒正美博客园文章)》 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我寫過不少文章來討論為什么移動Web應用程序很慢,這也引起了不少的討論。但是不幸的是,這些討論沒有像我喜歡的那樣的基于事實。

所以我這篇文章的目地就是給這些問題帶來一些真正的證據,而不是僅僅過來對罵。在這篇文章的中,你可以看到基準測試(benchmark),可以看到專家的觀點,你甚至可以看到非常誠實(honest-to-God)的期刊文章。這篇文章有超過100個引用(不是開玩笑)。我不保證這篇文章能使你信服,甚至不保證這篇文章中的所有內容都是正確的(在這樣大規模的文章中做到這一點幾乎是不可能的),但是我可以保證這是一篇關于許多iOS開發者都抱有的想法——移動Web應用很慢并且會在可預計的未來繼續如此——分析最完備和全面的文章。

現在我要警告你:這是一篇長得嚇人的文章,差不多10000字。當然,這是我故意的。我更喜歡好文章,而不是流行的文章。我嘗試使得這篇文章成為前者,同時宣揚我認同的風氣:我們應該鼓勵那些優秀的、基于證據的、有趣的討論,不鼓勵那些詼諧、嘩眾取寵的評論。

我寫這篇的文章,在某種程度上是因為這是話題已經到了一種爭論不休的地步。這不是另一篇爭論的文章,如果你想看到30秒左右的對罵:“真的!Web應用很渣!”和“誰說的?Web程序挺好!”,那么這篇文章不適合你。另一方面,據我所知,到現在為止還沒有一個關于這個話題全面的、正式的、理性的討論。這篇文章中我嘗試去理性地討論這個激起千層浪的話題,盡管這可能是一個非常愚蠢的想法。這里我給自己辯護一下,我相信這個問題與那些本來可以更好地去討論卻沒有這樣做的人更有關系,而不是主題本身。

如果你想知道你那些原生代碼(native code)程序員朋友為什么在如今開放的網絡革命時期還在寫著萬惡的原生代碼,那就把本頁面加入書簽吧,給自己倒杯咖啡,找出一個下午的時間,找到一個舒服的椅子,然后我們就正式開始吧!

簡單回顧

我上一篇博客中寫道:基于SunSpider的benchmark給出的數據可以看出當今的移動Web應用很慢。

如果你認為“Web應用程序”就是“一個網頁加上一兩個按鈕”,那么你就可以讓那些花哨的benchmark——比如SunSpider——滾一邊去。但是如果你認為“Web應用程序”是指“簡單的文字處理,簡單的照片編輯,本地存儲和屏幕之間的切換動畫”,那么除非你有想死的心,否則你永遠不會愿意在ARM上寫Web應用程序。

你應該先讀一下那篇文章,但是我還是在這邊給你看下benchmark:

關于這個benchmark,主要三種主要的批評:

1. JS比原生代碼要慢并不是什么新鮮事了,每個人在上第一學期的計算機基礎課時討論編譯型語言、JIT語言和解釋型語言是時候就知道了。問題是JS是不是慢到已經成為你現在所寫軟件的大問題了,但是像這樣的benchmark并不能說明這個問題。

2. JS是很慢,這也的確是個問題,但是它在變得越來越快,所以在不久的未來,我們可以發現它不會那么慢了。所以大家一起學JS吧。

3. 我是Python/PHP/Ruby的服務器端的開發者,我不知道你們在說什么。我知道我的服務器比你們的移動設備快,但是如果我可以自信地保證使用真正的解釋型語言寫出支持上千個用戶的代碼,你們難道不能用一個帶有高性能JIT的語言寫出一個支持單個用戶的代碼嗎?真的有那么難嗎?

我有一個相當高的目標,那就是反駁以上所有觀點:是的,JS的確是慢到一定程度了;不,它在不久的未來不會變得有多快;不,你在服務器端的編程經驗不能正確地映射到移動應用中。

但是真正的問題在于,在所有討論這個話題的文章里面,基本上沒有人真正量化JS到底有多慢,或者提供某種真正有用的比較標準(相對于什么來說慢)。為了糾正這樣的情況,我在這篇文章中提出了三種(不僅僅是一種)比較JavaScript性能的辦法。我不會說“JS在什么情況下都慢”,而是真正量化它慢的程度,并且將它跟我們再平常編程經驗中的事情做對比,這樣你就可以根據這個結果結合自己的編程平臺做出決定,你也可以自己計算下看看是否JavaScript適合你自己的特定問題。

OK,但是JS的性能相比于原生代碼到底如何?

這是一個好問題。為了回答這個問題,我從Benchmark Game中隨意抓取了一個基準測試。然后我找到了一個做同樣benchmark的較老的C程序(老到不像很多新程序有一些x86特性)。我在自己的iPhone 4S上分別測試Nitro和LLVM。所有的代碼已經傳到了Github。

這是一個隨機的測試,正如日常生活中運行的代碼一樣。如果你想要一個更好的實驗,可以自己運行。我運行這個實驗還有另外一個原因,就是因為其它的實驗都不存在LLVM和Nitro的對比。

在這個綜合的基準測試中,LLVM一致地比Nitro快4.5倍:

如果你在想“如果是計算密集型(CPU-bound)的功能,本地代碼比Nitro JS快多少呢”,那么答案是差不多5倍。這個結果大致上和Benchmark Game在x86/GCC/V8上面的結果一致,那里面的GCC/x86通常比V8/x86快2到9倍。所以結果大致上是正確的,無論是ARM還是x86。

但是1/5的性能對每個人來說還不夠好嗎?

在x86上是足夠好了。當渲染一個電子表格的時候,CPU的計算能有多密集呢?其實并不是那么難。問題是,ARM不是x86。

根據GeekBench的結果,最新的MacBook Pro的性能是最新的iPhone性能的10倍。這其實不算太大問題——電子表格沒那么復雜。我們可以忍受10%的性能。但是我還要把它除以5?好家伙!我們現在只有桌面性能的2%了。

OK,但是文字處理到底有多難?我們可不可以用一個m68k芯片加上一個協處理器來搞定呢?這是一個可以回答的問題。你可能記不起來,Google Doc的實時協作之前事實上還不是一個正式的功能,后來他們進行了大規模的重寫并且在2010年4月份加入到Google Doc里面。我們來看一下2010年瀏覽器的性能:

從圖中可以清晰地看到,iPhone 4S在Google Docs的實時協作方面完全不是桌面網頁瀏覽器的對手。當然了,它還是可以跟IE8比上一比的。恭喜iPhone 4S,可喜可賀。

我們再看看另外一個正經的JavaScript應用:Google Wave。Wave從來沒有支持IE8,因為它實在是太慢了。

看到這些瀏覽器比iPhone 4S快多少了嗎?

注意,所有支持的瀏覽器的得分都低于1000,其中那個得分3800的因為太慢了而被忽略了。iPhone得分為2400。差不多和IE8一樣,太慢幾乎無法運行。

這邊要說明的是,在移動設備上實現實時協作是可能的,只是不太可能用JavaScript來實現。原生代碼和Web應用的性能差距基本上和Firefox與IE8的性能差距差不多,這么大的差距足以影響正常的工作。

但是我感覺V8或者是現代JS已經有了接近C的性能了?

這取決于你怎么理解“接近”了。如果你的C程序運行了10ms,那么一個運行50ms的JavaScript程序差不多是接近C的速度了。如果你的C程序運行了10s,那么一個運行了50s的JavaScript程序對于大多數正常人來說很可能就不是接近C的速度了。

硬件角度

1/5的速度在x86上是沒問題的,畢竟x86起點就比ARM快10倍,你還有很多上升空間。解決方案顯然是讓ARM變成10倍快,這樣就可以跟x86競爭了,然后我們就可以不用做任何工作就可以得到桌面環境的JS性能了。

這個方法行不行得通取決于你是否相信摩爾定律,以及給每個芯片配置一個3盎司的電池是否可行。我不是一個硬件工程師,但是我曾經為一家大型半導體公司工作過,那里的人告訴我說當今硬件的性能基本上是制作工藝(process)起的作用。iPhone 5令人印象深刻的性能主要是因為其芯片工藝從45nm做到了32nm,減少了差不多1/3。但是如果想繼續這么做,蘋果就要達到22nm的工藝。

順便提一下,Intel22nm工藝的Atom處理器現在還沒上市。而且Intel不得不重新發明全新的半導體,畢竟原來的半導體在22nm級別已經不適用了。他們會把工藝授權給ARM?再好好想想吧。如今22nm的產品少之又少,而且大部分被Intel掌控著。

事實上,ARM似乎已經在著手在明年嘗試28nm了(看看A7),同時Intel正在嘗試22nm甚至在稍微晚些時候嘗試20nm。從純硬件的角度,我感覺具有x86級別性能的x86芯片很可能遠遠比具有x86性能的ARM芯片更早登錄智能手機市場。

看一個前Intel工程師給我發的郵件:

我是一個前Intel工程師,剛開始從事于移動微處理器的工作,后來工作轉向了Atom處理器。無論如何,我有一個很偏激的觀點,即x86從較大的核心轉向手機市場的難度遠比ARM從頭開始設計技術細節以達到x86的性能級別的難度要低很多。

再看一個機器人領域的工程師給我發的郵件:

你說得非常對,這些(譯注:指的是ARM的發展)不會帶來多大的性能提升,Intel可能在近幾年之內就會有更高性能的移動處理器。事實上,移動處理器當前和桌面處理器面臨著同樣的問題,即工作頻率達到3GHz左右的時候,再提高時鐘速度就不可避免地使得功耗大大增加。這種情況同樣會發生在下一代工藝上,盡管IPC(Instruction per Clock,即CPU每一時鐘周期內所執行的指令多少)會得到一些提高(差不多10%-20%)。在面臨這種限制的情況下,桌面處理器開始向雙核和四核方向變化,但是移動處理器現在已經是雙核和四核了,所以想提高性能不是那么容易。

摩爾定律無論怎么說都可能是正確的,但是這需要整個移動生態環境向x86環境轉變。這并非完全不可能,畢竟曾經有人做過這樣的事。但那是在移動處理器一年才賣出去100萬個的時候做的,不像現在,每個季度就可以賣出62萬個芯片。那個時候現成的虛擬化環境可以模擬出老架構的60%的速度,而按照現在的研究來看,虛擬化系統上運行優化過的(O3)ARM代碼的速度已經接近27%了。

如果你堅信JavaScript的性能最終會到達一個合理的水平,那么硬件性能的提升絕對是最好的方式。要么Intel會在5年之內開發出可行的iPhone芯片(這是有可能的),并且蘋果迅速轉向x86架構(這是不太可能的),或者ARM能夠在未來的10年之內得到性能的飛躍。但是在我看來,10年是一個很長的時間,長到足夠使某件事情可能成功。

恐怕我的硬件的知識只能分析到這里了。我可以告訴你的是,如果你相信ARM可以在未來的5年之內填補與x86之間的性能差距,那么第一步就是找到一個在ARM或者x86上工作的人(也就是真正懂硬件的人),讓他同意你的看法。我寫這篇文章之前,曾近咨詢過很多有很高資質的硬件工程師,他們所有人都拒絕公開發表這個觀點,這讓我感覺這個觀點不是很靠譜。

軟件角度

這是一個很多優秀軟件工程師犯錯誤的地方。他們的思路是這樣的:JavaScript已經變得更快了,并且它會變得更快。

這個觀點的前一部分是正確的,JavaScript的確變得快很多。但是我們現在已經達到了JavaScript性能的頂點了,它不可能變得更快多少。

為什么?其實前一部分JavaScript的性能提升從某種程度上是硬件的原因,正如Jeff Atwood寫道:

我感覺從1996到2006之間JavaScript的性能變快了100倍。如果Web 2.0主要建立在JavaScript上的話,這很可能主要是因為摩爾定律所帶來的硬件性能提升。

如果我們把JS的性能提升總結為硬件性能提升的話,那么JS的已有的硬件性能提升不能預測未來的軟件性能提升。這就是為什么如果你相信JS會變得更快的話,最有可能的方式就是硬件變得更快,因為歷史趨勢就是如此。

那么JIT如何呢?V8,Nitro/SFX,TraceMonkey/IonMonkey,Chakra等等?當然,當他們剛剛問世的時候,的確是很了不起的(但或許不像你認為的那么了不起)。V8在2008年9月發布,我找到了一份差不多那個時候同期的Firefox 3.0.3,看看它的性能:

不要誤解我的意思,9倍的性能提升的確值得稱贊,畢竟這差不多是ARM和x86之間的性能差距了。即便如此,Chrome 8和Chrome 26之間的性能卻呈現出了水平線,因為自從2008開始,幾乎沒有什么重大的事情發生。其他瀏覽器廠商都已經趕上來了,有些快有些慢,但是沒人真正提高過JavaScript的性能了。

JavaScript性能在提升嗎?

這是我Mac上的Chrome 8(可運行的最早版本,2010年12月份的版本)和Chrome 26。

看不出差別?因為根本沒有差別。JavaScript的性能最近根本沒有得到大的提升

如果你感覺現在的瀏覽器比2010年的瀏覽器跑的快的話,那很可能是因為你有了一臺更快的電腦,但是這與Chrome的性能提升沒什么關系。

更新:有些聰明的人指出SunSpider現在不是一個好的benchmark(并且拒絕提供任何實際的數字或其它什么)。為了能夠可以理性地討論,我在一些舊版本的Chrome上面運行Octane(一個Google的benchmark),的確顯示出了一些性能提升:

在我看來,在這個期間的性能提升還是太小,不足以支撐JS馬上就會足夠快這樣的論調。然而,要說我過分強調這個情況也沒錯,畢竟JavaScript的計算密集型操作的確在發生變化。但是推我來說,這些數字可以得出更大的推斷:這些性能提升的幅度還不足以在一定時間之內使得JavaScript的速度趕上原生代碼。你需要性能達到2-9倍才能跟LLVM競爭。這些提升是好的,但還不足夠好。更新結束

問題是,讓JavaScript采用JIT技術是一個60年前就有的想法,并且這60年來一直有人在研究。數以千計的你可能想到的編程語言對JIT的實現都證明這是一個好主意。但是既然我們已經做到了,我們已經用完了這個60年前的想法。伙計們,就是這樣的,表演結束了。或許我們可以在未來的60年之內想到另一個好辦法。

但是Safari恐怕比以前要快吧?

Safari 7 是不是比其它的瀏覽器快3.8倍?

這個結論或許對蘋果來說很容易得到,但是這個版本的Safari在NDA協議之下,所以沒有人能夠公開關于Safari性能的獨立參數。但是我可以僅僅根據現在已經得到的信息來做一些分析。

我發現一些現象很有意思。第一、蘋果官方在公開的JSBench上的數據要比在他們在較老的benchmark(如SunSpider)上給出的數據高出不少。現在JSBench背后有一些非常酷的名字,包括JavaScript之父Brenden Eich。但是和傳統的benchmark不一樣,JSBench的工作方式不會考慮整數和其它重要因素,它反而自動為Amazon、Facebook和Twitter提供的內容進行優化,而且根據它們提供的內容來建立benchmark。

如果你在寫一個多數人用來瀏覽Facebook的瀏覽器,我可以理解用一個只測試Facebook性能的benchmark是很有用的。但是從另外的角度講,如果你在寫一個電子表格的程序,或者游戲,或是一個圖片過濾應用,在我看來傳統的benchmark(注重整數運算和md5哈希)會更能夠準確地幫你預測出Facebook的分析代碼有多快。

另一個重要的事實是,蘋果聲稱的在SunSpider上性能的提升并不能代表其它東西的提升,Eich et al在這篇提到蘋果所偏愛的benchmark的文章中寫道:

圖中清楚地顯示出了Firefox的3.6版本比1.5版本在SunSpider的benchmark上性能提高了13倍。但是當我們看它在amazon的benchmark上的性能表現時,發現只有較謙虛的3倍的提升。更有意思的是,在過去的兩年時間,在amazon的benchmark上的性能提升其實是被夸大了。這意味著在SunSpider上做的一些優化幾乎對amazon沒有太大作用。

在這篇文章中,JavaScript之父和Mozilla的首席架構師之一曾公開承認在過去的兩年之內Amazon的JavaScript性能幾乎沒有提升,沒有發生過什么特別重要的事情。從這一點你也可以看出來,那些營銷人員這些年都在過分夸大自己產品的性能。

他們繼續爭辯道:對于那些人們用來瀏覽Amazon網頁的瀏覽器來說,運行Amazon的benchmark比運行其它benchmark要更能準確地預測出瀏覽器的性能(這是當然了……),但是這些手段不會幫助你更好地寫出一個照片處理程序。

但是無論怎么說,從我可以看到的公開信息來看,蘋果聲稱的3.8倍的性能提升對你來說幾乎沒有什么太有用的東西。我可以告訴你,如果我有一些能夠反駁蘋果聲稱擊敗Chrome的benchmark的話,我將不被允許發布它們。

所以,我們總結一下這一節,如果有一些人拿出一個柱狀圖來顯示網頁瀏覽器變得更快了,那并不能真正說明整個JS變得更快了。

但是還有一個更大的問題。

并非為性能而設計

下面這段話出自于Herb Sutter,現代C++中最著名的人物之一:

在過去的20年里,有一種很難根除的文化基因——只要的等下一代的(包括JIT和靜態)編譯器出來,托管語言就會變得和原生語言一樣高效。是的,我完全希望C#和Java編譯器能夠不斷提高,包括JIT和類NGEN的靜態編譯器。但是,它們永遠不會消除與原生代碼之間的效率差距,有兩個原因:一、JIT編譯不是主要問題。根本原因更為基本:托管語言在編程人員的開發效率(當時的確是個問題)和程序的運行效率之間從設計上做了故意的妥協。特別的,托管語言選擇選擇在所有的程序上添加額外的性能開銷,盡管你根本沒有用到一個特性,你都會受到這個特性帶來的額外的性能開銷。主要的例子是assumption/reliance、垃圾回收、虛擬運行環境和元數據等功能在托管語言中是默認打開。當然還有其它的例子,比如托管代碼中函數默認是virtual的,而C++代碼中的函數是默認inline的。1盎司(譯注:12盎司=1磅)的內聯阻止(inlining prevention)抵得上1磅的去虛擬化優化(devirtualization optimization cure)。

下面這段話出自于Mono項目組的Miguel de Icaza,他是為數不多的“維護著一個主流JIT編譯器的人”。他說道:

關于主流托管語言(.NET、Java和JavaScript)的虛擬機之間的差異,有一個比較準確的說法。托管語言的設計者在他們設計一門語言的過程中更傾向于安全性,而不是性能。

或者你可以找Alex Gaynor談一談,他負責維護和優化Ruby的JIT編譯器,并且也為Python的JIT的優化工作做出了貢獻:

這是加在這些具有高生產力的動態語言身上的詛咒。它們使得創建一個哈希表十分容易。這是一件非常好的事情。我認為C程序員多數不太會使用哈希表,因為對他們來說用哈希表實在是是一件痛苦的事情。原因有二:第一,你沒有一個內置的哈希表;第二、當你嘗試去使用的時候,你會左右碰壁。對比來看,Python、Ruby和JavaScript程序員都過度使用哈希表了,因為使用它們實在太容易了……所以大家都不在乎。

Google似乎意識到了JavaScript正面臨著性能的瓶頸:

復雜的Web應用(這是Google比較擅長的)在某些平臺上正在面臨著不小的掙扎,主要是因為這些應用用到了一些不能被性能調優的語言,這些語言有內在的性能問題。

最后,我們聽聽權威人士的意見。我的一個讀者向我指出這段Brenden Eich的評論。正如你所知,他是JavaScript之父。

有一點Mike沒有強調:得到一個更簡單的語言。Lua比JS簡單得多。這意味著你可以寫出一個簡單的解釋器使得它跑得足夠快,同時能夠保持對trace-JIT代碼的尊重(這和JS不同)。

稍微下面一點又提到:

關于JS和Lua之間的差別,你可以說這完全是正確的設計和工程上的問題,但是內在的復雜性區別還是很大。你當然可以把較難的案例從熱路徑中刪除,但是他們也會因此付出代價。JS比Lua有更多的更難的案例。一個例子是:Lua(沒有顯式的元表使用)沒有像JS中的原型對象鏈(prototype object chain)的東西。

在這些真正從事相關工作的人當中,持有JS或者是其它動態語言能夠趕上C語言性能這個觀點的,只占極少數(very much the minority)。到處都有和主流想法不同的人,所以根本無法沒有什么辦法能夠達到真正的一致。但是,從語言的角度說到JIT語言是否能夠趕上原生語言的效率,他們給出的答案都是“不,不可能,除非修改語言本身或者API”。

但是還有一個更更大的問題。

都是因為垃圾回收

你可以發現,CPU問題、CPU相關的benchmark以及所有有關CPU的設計決定,都只是故事的一半。故事的另一半是內存。內存問題現在看來是如此的巨大,大到使整個CPU的問題看上去都僅僅是冰山一角。實際上可以討論的是,所有關于CPU的討論都是轉移注意力的話題(red herring)。你接下來要閱讀的應該會完全改變你對移動設備軟件開發的理解。

2012年,蘋果做了一件非常奇怪的事情(當然了,除非你是John Gruber,能夠看到它的到來)。他們把垃圾回收從OSX中除去了。真的,你可以去看看程序員指南。標題右邊有一個大大的“不推薦(Not Recommended)”。如果你之前是Ruby、Python、JavaScript、Java、C#或是其它任何1990年代之后誕生的語言的開發者,這應該會讓你感覺很奇怪。但是這很可能不會影響到你,因為你很可能不在Mac下面使用ObjC,在HN點擊下一個鏈接。但是這仍然看上去很奇怪,畢竟GC一直被大家使用著,而且它的價值也得到了證明。為什么你要反對它呢?蘋果是這么說的:

我們十分堅信ARC才是內存管理的正確方式,所以我們決定使OSX上的垃圾回收變成過時的(deprecate)。——ession 101, Platforms Kickoff, 2012, ~01:13:50

這段話沒有告訴你的是,當聽到這句話的時候,臺下的觀眾爆發出了熱烈的掌聲。OK,這就變得真的非常奇怪了。你是不是在告訴我有那么一個屋子里的程序員在為了垃圾回收之前的那種混亂的回歸鼓掌?你可以想象下如果Matz在RubyConf上宣布GC過時的時候整個會場的寂靜,幾乎一顆針掉在地上都聽得到聲音。而這群人卻因此而高興?太古怪了吧?

你應該根據這些古怪的反應發現一些你現在看不到但是卻是在真正發生的事情,而不是僅僅把這些事情歸結于這群人對于蘋果的狂熱。這些正在發生的事情就是我們下面就要討論的主題。

思維過程是這樣的:把一個工作得好好的垃圾回收器從一個語言中拿出來簡直是瘋了吧?一個簡答的解釋可能是ARC可能僅僅是蘋果為了給垃圾回收披上一層美麗新裝而創造的一個營銷詞匯,所以這些開發者是為了這種升級而不是降級而鼓掌的。事實上,這就是很多iOS簇擁們的抱有的想法。

ARC不是一個垃圾收集器

所有的那些認為ARC是某種垃圾回收器的人,我想通過下面這個蘋果的幻燈片給你迎頭一擊(beat your face):

這與和垃圾回收有類似名字的算法無關。它不是垃圾回收,他不是什么像垃圾回收的東西,它表現得一點都不像垃圾回收,它不會打亂任何保留周期,它沒有去回收任何東西,它甚至沒有去做掃描。OK,故事結束,它絕對不是垃圾回收。

因為正式的文檔還在NDA協議下,所以有很多傳言認為這并不是真的(但是細則已經可以看得到了,沒有任何借口了),而且很多博客都紛紛說這些不是真的。它是真的。不要再討論了。

垃圾回收不像你的經驗讓你感覺的那樣可行

這是蘋果在壓力之下給出的關于ARC和GC的說法:

在愿望清單的頂端上我們能為你們做的最重要的事情就是把垃圾回收帶到了iOS中,而這恰恰是我們最不應該做的。不幸的是,垃圾回收給性能帶來了很多次優的影響。你程序中的垃圾回收會使得你的內存使用率變得很高,而且垃圾回收器經常在不確定的時間點上被觸發而導致非常高的CPU使用率,從而打斷用戶正在做的事情。這就是為什么GC不適合在我們的移動平臺上使用的原因。對比來看,帶有獲取和釋放(retain/release)的手動內存管理學起來比較難,坦率的講有些像痔瘡(譯注:這個翻譯可能不準確,原文是pain in the ass)。但是它產生了更好更可預測的性能,這也是為什么我們選擇手動內存管理作為我們內存管理策略的基礎的原因。因為在外面真實的世界,高性能以及用戶體驗的連續性是我們的用戶最看重的。(譯注:在蘋果看來,用戶體驗要比開發者體驗重要。)~Session 300, Developer Tools Kickoff, 2011, 00:47:49

但是這還是完全瘋狂了,不是嗎?這只是開始:

1. 這可能會直接影響你整個職業生涯對于垃圾回收語言給桌面和服務器上帶來影響的理解;

2. Windows Mobile、Andriod、Mono Touch以及所有其它移動平臺上的GC似乎都可以挺好地工作。

所以讓我們反過來看這個問題。

移動平臺上的GC和桌面平臺上的GC不是同一回事

我知道你在想什么,你是一個有了N年開發經驗的Python程序員。現在是2013年了,垃圾回收完全可以解決問題。

這是一篇你想看到的文章,似乎問題并沒有解決:

如果你在這篇文章中其它什么都記不得,那么請記住這張圖。Y軸是垃圾回收所用的時間,X軸是“相對的內存足跡”,相對于什么?相對于所需的最小內存

這張圖想說明的是,“如果你有6倍以上你實際需要的內存,那么使用垃圾回收是沒有問題的。但是如果你只有小于4倍你實際需要的內存,那么災難就要降臨了。”。但是不要相信我的話:

特別的,如果垃圾回收時系統擁有5倍于所需的內存時,它的運行時性能差不多甚至是超過顯式內存管理。但是,垃圾回收的性能在必須使用小堆(small heap)的情況下會出現急劇下降。如果有3倍于所需的內存的話,它會跑得慢17%;如果只有2倍于所需的內存的話,會慢70%。垃圾回收比物理內存的換頁更容易受到內存不足的影響。在這種情況下,我們所測試的所有垃圾回收器相對于手動內存管理都出現指數級的性能下降

現在我們再來比較一下顯式內存管理的策略:

這些圖顯示,如果可用內存在合理的范圍的情況下(但不足以容得下整個應用),顯式內存管理器都要比垃圾回收器快太多。比如說,pesudoJBB以63M的可用內存運行,Lea allocator在25s的時間內完成運行。在相同可用的內存下運行GenMS,花了超過10倍的時間來運行(255s)。我們可以看到其它benchmark套件的相同趨勢。最值得一提的例子是213 javac和Lea allocator一起在36M的內存下運行,總體運行時間是14s,而與GenMS一起運行的情況下,運行時間為211s,用了超過15倍的時間。

基本的事實是,在內存受限的環境下垃圾回收性能的下降是指數級的。如果你在桌面電腦上寫Python或者JS程序的話,你整個的體驗可能是這幅圖的右邊部分,你可以一輩子都體會不到垃圾回收帶來的性能問題。花點時間想想這幅圖的左邊部分,并且想想我們該如何應對。

iOS上有多少可用內存?

這一點很難準確地描述。從iPhone 4到iPhone 5,這些設備上的物理內存從512M到1G不等。但是其中很大一部分為系統預留了,還有更大的一部分為多任務處理預留了。所以唯一真正的方法是在不同的情況下進行嘗試。Jan Ilavsky寫了一個非常有用的工具來完成這個任務,但是貌似沒有人公開任何數據。但這一點現在已經改變了。

現在,在一種“正常”的情況下(這一點很難具體說清楚是什么意思)進行測試是非常重要的,因為如果你在一臺剛剛啟動的機器上測試的話,你會得到更好的數據,畢竟你的系統里面沒有Safari所打開的頁面。所以我就在“真實世界”的情況下拿出一些我公寓里的設備進行本次benchmark。

你可以點擊進去看看詳細的結果,大體上來說,在iPhone 4S上,當你的程序使用了40M內存的時候就會得到警告,而使用了213M內存的時候,程序就會被殺死;在iPad 3上,使用400M左右時獲得警告,而使用550M左右的時候,程序被殺死。當然了,這些也僅僅是數字而已,如果你的用戶在聽音樂或者在后臺跑一些程序,你可用的內存會比我測試里面可用的內存更少,這只是給你一個思路而已。這么多內存看上去不少(213M應該對每個人來說都足夠了,是吧?),但實際上這還不夠。舉個例子,iPhone 4S拍照時的分辨率為3264*2448,每張照片有超過30M的位圖數據。如果你在內存里加載了2張照片你就會獲得警告,而如果加載了7張照片,程序就會被殺死。哦,你打算給你寫個循環在你的相冊中逐個處理?程序會被殺死。

還有一點需要十分注意:實際的情況下,一張照片可能存在于內存的多個位置。比如說,如果你在拍照片,那么你在以下位置都有數據:1) 你通過屏幕看到的攝像頭中的數據,2) 攝像頭實際上拍到的照片數據,3) 你嘗試寫到存儲卡中的壓縮JPEG緩沖數據;4) 你準備在下一個屏中顯示的數據;5) 你準備上傳到某個服務器中的數據。

在一些點上你會發現,保留30M的緩沖區去顯示照片縮略圖是一個非常不好的想法,因為這樣你會引入更多的數據:6) 用來保留下一屏顯示合適大小照片的緩存;7) 用于在后臺重新調整照片大小的緩存(在前臺做實在太慢了)。然后你發現你可能真正需要5個不同的大小,然后你的程序就不是一般的慢了,而是慢到讓人抓狂。在實際的應用程序中,僅僅是處理一個照片就會遇到內存的瓶頸并非罕見的事情。但是不要相信我說的話:

你能做的最糟糕的事情就是在內存不充足的情況下在內存中緩存圖片。當一張圖片被畫成位圖或者顯示到屏幕上時,我們就不得不把照片解碼為位圖。位圖的每個像素點為4字節,無論原始圖片多大都是如此。每當我們將它解碼一次,位圖就會綁定到圖片本身并且一直維持到這個對象生命周期結束之時。所以如果你把圖片加載到內存而且曾經顯示過一次,那你現在就會在內存中保留整個位圖,直到你釋放它為止。所以永遠不要把UIImage或者CGImage放到緩存中,除非你有一個非常明確(但愿是非常短期的)的目標。- Session 318, iOS Performance In Depth, 2011

你甚至不要相信上面的話!你給自己分配的內存其實只是冰山一角。下圖是蘋果一張幻燈片中給出的冰山的全圖。Session 242, iOS App Performance – Memory, 2012:

你可以從兩方面考慮這個問題。第一、在213M可用內存的情況下,在iOS上寫一個照片處理程序比在桌面上寫一個要困難許多。第二,你在iOS上寫一個照片處理程序時,你對內存的需要會更多,因為你的桌面程序沒有一個可以放進你口袋的攝像頭

我們可以看看另外一個例子:在iPad 3上,你要顯示一個視頻,這種照片的大小很可能比你電腦上的視頻要大不少(后面的高分辨率攝像頭,差不多2000-4000像素)。每一幀要顯示的就是一個12M的位圖。如果你對內存的使用很節省的話,每一時刻你可以在內存中保留45幀的未壓縮視頻或動畫緩存,也就是在30fps的情況下每1.5s,在60fps的情況下0.75s。你想為一個全屏的動畫預留緩存?應用被殺死。值得指出的是,AirPlay的延遲是2s,所以對于任何多媒體類型的應用,你幾乎是保證沒有足夠的內存

這種情況下我們同樣面臨著和照片的多個數據拷貝差不多的問題。比如說,蘋果指出,“每一個UIView背后都有一個CALayer,而且只要CALayer存在于在這個層次中,對應的圖片數據會一直保存在內存中”。這意味著,很可能有許多中間的渲染數據的拷貝存在于內存中。

還有剪切矩形和備份存儲這些可能會占用內存的事情。這樣的數據處理架構事實上是非常高效的,但是這帶來的代價是程序會盡可能地占用內存。iOS不是為低內存使用而設計的,它是為了快速運行而設計的。這沒有和垃圾回收扯在一起。

我們同樣需要從兩個方面考慮問題。第一,你在一種內存非常緊缺的情況下做出動畫效果;第二、做出這樣超級高質量的視頻和動畫是需要極大的內存的。而為了使得普通消費者買得起消費級別的、具有高攝像頭分辨率的產品,這種糟糕的、內存受限的環境幾乎是必然的選擇。如果你想寫一個軟件來毫無壓力地播放視頻,那么你就得說服別人為了屏幕多花700美元,或者花500美元買一個iPad,它實際上已經包含了一個內置的電腦。

我們會獲得更多內存嗎?(更新)

一些聰明的人說:“OK,你說了很多關于我們不會有更快的CPU。但是我們應該回有更多的內存吧?這正是桌面環境上發生的事情。”

這種理論的一個問題是,ARM平臺上的內存就在處理器本身上,這被稱為package on package。所以在ARM上獲得更多的內存幾乎和提高CPU性能是同一個問題,因為它們歸根結底是同一件事情:在CPU上集成更多的晶體管。內存晶體管處理起來稍微容易一些,因為它們是統一的,所以不是那么難,但實際上也不是那么簡單。

如果你看看iFixit的A6的照片,你會發現在CPU模具最表面的硅幾乎100%都是內存。這意味著,如果你想擁有更多的內存,你要么使得制作工藝更精細,要么提高模具的大小。事實上,如果你把工藝的大小做歸一化處理,那么其實伴隨著每次內存升級,你的模具都在變得更大。

硅其實是一種不完美的材料,為了獲得更大的尺寸所付出的的代價是指數級增長的。它們也很難維持較低的溫度,也很難放進小設備中。它們和制作出更好的CPU的目標是重復的,因為內存也面臨同樣的問題:CPU最上層的硅中需要放進更多的晶體管。

搞不懂的是,面臨著PoP的這些問題,CPU廠商們繼續使用PoP的方式為系統提供內存。我還沒有遇到任何ARM工程師能夠解釋這一點。或許以下的評論可能會幫助我們理解。我們有可能從PoP架構轉向電腦中采用的分離內存模塊,而且我感覺這比較可行。原因很簡單,將內存分為單獨的模塊比制造出更大的芯片和進一步減小制作工藝對廠商來說毫無疑問成本是更低的。但是現在所有的廠商都在不停地嘗試提高制作工藝或者制作出更大的芯片,而不是把內存模塊獨立出來。

然而,一些聰明的工程師曾經給我發了郵件讓我填補了這方面的空白。

一個前Intel工程師說道:

PoP內存模型可以大量減少內存延遲,也可以減輕路由問題。但是我不是ARM工程師,也不確定這是否是全部的原因。

一個機器人學的工程師提到:

當PoP內存不夠用時,“3D”內存會提供足夠大的內存:內存芯片在生產的時候堆疊在一起,1G的RAM在同一層堆成10層向上,就像現在的硬件模型一樣。但是,這樣的開銷會很大,頻率和電壓都要相應地降低使得電力消耗處于一個合理的水平。

移動RAM的帶寬不會像最近提高得這么快了。帶寬被連接SoC和RAM包的總線的數量所限制。當前RAM的總線多數使用的是高性能SoC的圓柱體表面。SoC的中間部分不能用來加入RAM總線,因為這些RAM包是層疊的。接下來的重大改變應該回來自于將SoC和內存放在一個單獨的、高度集成的包中,允許更小、更密集和大量的RAM總線(更大的帶寬),并給SoC設計和更低的RAM電壓帶來更多自由。根據這樣的設計,更大的緩存也就可能成為現實,因為RAM可能用更高的帶寬放在SoC模具中。

但是Mono/Andriod/Windows Mobile平臺怎么解決這個問題呢?

這個問題事實上有兩個答案。第一個答案我們可以從圖中看出。如果你發現你有6倍于所需的內存,垃圾回收其實是非常快的。舉個例子來說,如果你在寫一個文本編輯器,你可能可以用35M的內存完成自己要做的所有事情,這是我的iPhone 4S會崩潰內存上界的1/6。你可能在Mono上寫個文本編輯器,看到非常不錯的性能,然后從這個例子中得出如下結論:垃圾回收十分適合這個任務。你是對的。

然而Xamarin框架在案例中有一個飛行器模擬器。很顯然的是,垃圾回收對于現實生活中的較大的應用程序來說是不適合的。難道不是嗎?

你在開發和維護這個游戲時一定會遇到什么樣的問題?“性能一直是一個大問題,而且將持續是我們再跨平臺中會遇到的最大的問題之一。最初的Windows Phone設備是非常慢的,我們不得不花很多時間來優化程序,使得它達到一個體面的幀率。我們不僅僅在飛行模擬代碼上進行優化,而且在3D引擎上優化。垃圾回收和GPU的弱點是最大的瓶頸。

程序員不約而同地聲稱垃圾回收是最大的瓶頸。當你的案例中的人在抱怨的時候,那應該是一個足夠引起你重視的線索了。但是Xamarin可能是一個局外人,我們還是來看看Andriod開發者怎么說的吧:

請記住下面是我在我的Galaxy Nexus上運行的情況:無論怎么說都是性能非常不錯的設備。但是看看渲染的時間!我在電腦上只要花幾百毫秒就可以渲染出這些圖片,可是在這臺手機上卻花了超過兩個數量級的時間。渲染“inferno”圖片超過6s?這簡直是瘋了吧!要生成一副圖片,需要10-15倍的時間來運行垃圾回收器。

另一個開發者:

如果你想在Andriod手機上為實時物體識別或者基于內容的現實增強進行對照相機圖片的處理,那么你很可能聽說過照相機預覽回調(Camera Preview Callback)的內存問題。每次Java程序嘗試從系統獲取預覽圖片時,系統就會創建一大塊新的內存。當垃圾回收器釋放這塊內存時,系統會卡住(freezes)100ms到200ms。如果系統在高負載的情況下,事情可能會變得非常糟糕(我曾經在手機上做過物體識別——天吶,它幾乎把整個CPU都占用了)。如果你看過Andriod 1.6的源代碼你就會知道,這只是因為這個功能的包裝類(wrapper,用來包裝原生代碼)每次在一個新的幀可用時都會申請一個新的字節數組。當然,內置的原生代碼可以避免這個問題

或者,我還可以去看看Stack Overflow:

我負責在Andriod平臺上為Java寫的交互式游戲進行性能調優。很多時候,當候垃圾回收開始工作會讓使得游戲的畫圖和交互功能發生打嗝。通常情況下這種打嗝持續不到1/10s,但有的時候在比較慢的設備上會長達200ms。如果我在一個內部循環中使用樹或者哈希表,我就就知道我要很小心,或者甚至不用Java標準的Collections框架,而是自己重新實現一個,因為我承擔不起垃圾回收帶來的額外開銷。

這是一個“接受的答案(accepted answer)”,有27個人贊同:

我也是Java手機游戲的開發者……避免垃圾回收(垃圾回收可能在某個點被出發從而大幅降低你游戲的性能)的最好方法就是不要再游戲的主循環中創建對象。實在沒有什么“簡潔”的方式來處理這種問題,或許只有手動追蹤這些對象了,真悲哀。這地也是目前大部分當前移動設備上性能優良的Java游戲所采取的的方式。

我們來看看Facebook的Jon Perlow怎么看待這個問題:

對于開發流暢的安卓應用來說,GC是一個非常大的性能問題。在Facebook,我們遇到的最大問題之一是GC會使得UI線程暫停。當我們處理很多位圖數據時,GC被觸發的頻率很高,而且難以避免。GC經常導致掉幀的問題。即使GC只會阻塞UI線程幾毫秒,但這卻會嚴重影響原本需要16毫秒的幀渲染。

OK,我們再聽聽一個微軟MVP的說法:

通常情況下,你的代碼在33.33ms之內就會完成執行,從而使得30fps的幀率變得很不錯。但是當GC運行的時候,它會占用那個時間。如果你的堆比較整潔和簡單,那么GC一般可以運行得不錯,不會對程序產生什么影響。但是讓一個簡單的堆處于一個使GC可以快速運行的情形是一件困難的編程任務,它要求大量的計劃和/或程序重寫,即使是這樣也不是完全安全的(有時在一個復雜的、有很多玩意的游戲中你的堆里面有很多內容)。更簡單的方法是(假設你能這么做),在游戲過程中限制甚至是禁用內存分配。

在有垃圾回收的情況下,在游戲中保證一定會贏的方法就是不要玩(作者的幽默,原文:the winning move is not play)。比這種哲理稍弱的一種形式如Andriod官方文檔中所說的:

對象創建永遠不是免費的。帶有線程級別內存池的垃圾回收器使得內存分配的成本變得稍微低一些,但是分配內存永遠比不分配內存開銷大。因為當你在程序中分配對象時,你會強制垃圾回收周期性地工作,從而使得用戶體驗不是那么流暢。Andriod 2.3當前引入的垃圾回收器有一些作用,但是要是應該避免不必要的工作。因此,你應該避免創建你不需要的對象實例。一般而言,盡可能不要創建短期臨時對象。越少的對象創建就意味著越低頻率的垃圾回收,從而提高用戶體驗。

還不信?那讓我來問問一位真正從事垃圾回收工作的工程師,他為移動設備實現垃圾回收器。

然而,WP7系統的手機CPU和內存性能正在大幅度地提升。游戲和大型Silverlight應用越來越多,這些程序會占用100M左右的內存。隨著內存的變得越來越大,很多對象擁有的引用會指數級地變多。在上面解釋的模式中,GC不得不去遍歷每個對象以及他們的引用,標記它們,然后清理沒喲引用指向的內存。所有GC的時間也大幅增加,并且成為這個應用的工作集(workingset)的一個函數。這會在大型XN游戲中和SL應用中導致程序卡住,體現在很長的啟動時間(因為GC有可能在游戲啟動的時候運行)或者游戲過程中的小問題。

還是不信?Chrome有一個測量GC性能的benchmark。我們來看看它都干嘛了:

你可以看到很多GC導致的卡頓。當然了,這是一個壓力測試,但還是能說明問題的。你真的愿意花幾秒時間來渲染一幀?你瘋了吧。

這么多引用,我才不會挨個看呢,直接告訴我結論就行了。

結論是:移動設備上的內存管理很難。iOS平臺的開發者已經形成了一種文化,即手動做大部分事情,讓編譯器做其它容易的部分。Andriod平臺形成的文化是,提高垃圾收集器的性能,但事實上開發者在實際開發中盡量避免使用它。這兩者的共同點是,大家在開發移動應用時,開始越來越多地考慮內存管理問題了。

當JavaScript、Ruby或是Python開發者聽到“垃圾收集器”這個詞時,他們習慣將它理解為“銀彈(silver bullet)垃圾收集器”,也就是“讓我不要讓我再考慮內存問題的垃圾收集器”。但是移動設備上根被沒有銀彈可言,每個人寫移動應用時都在考慮內存問題,不管他們是否使用了垃圾收集器。獲得“銀彈”內存管理方式的唯一方式就像我們在桌面環境上一樣,擁有10倍于程序實際需要內存。

JavaScript的整個設計基于一個思想,即不要擔心內存。看看Chromium開發者們怎么說:

有沒有任何一種方式強制chrome的js引擎進行垃圾回收?一般意義而言,沒有,這是從設計的角度就已經確定了的。

ECMAScript規范沒有提到“分配(allocation)”這個詞,唯一與“內存”相關的話題本質上就是說整個主題都是“實現相關的(host-defined)”。

ECMA 6的維基頁面上有幾頁提案的草稿,歸根結底是說(不是開玩笑):

“垃圾回收器不可以回收那些程序需要繼續使用來完成正確執行的內存。所有不能從根節點傳遞遍歷到的對象都應該最終被銷毀,防止程序因為內存耗盡而發生錯誤。”

是的,他們的確在思考將這個需求規約:垃圾回收器不應該回收那些不應該被回收的東西,但是應該回收那些需要被回收的。歡迎來到tautology club。但是下面這段話可能與我們的話題更相關:

然而,并沒有規范說明單個對象占用多少內存,也不太可能會有。因此當任何程序在內存耗盡的情況下,我們永遠不會得到任何保證,所以任何準確的、可觀察的下界。

用英語來說就是,JavaScript的思想(如果這算是一種思想的話)是你不應該能夠觀察到系統內存中的情況,想都不要想。這種思想和人們在寫實際的程序時候的想法簡直是令人難以置信的背道而馳(so unbelievably out of touch),我甚至找不到正確的詞語來向你形容。我的意思是,在iOS的世界里,我們并不相信垃圾回收器,我們感覺Andriod開發者都瘋了(nuts)。我懷疑Andriod開發者會這么認為:iOS開發者竟然會用手動內存管理,簡直是瘋子。但是你知道這兩個水火不容的陣營的人可以在哪件事情上達成共識嗎?那就是JavaScript開發者是真正的瘋子。你在移動平臺上寫出一個有點意思的程序,而從來不關心系統內存的分配和釋放,是絕對不可能的(absolutely zero chance)。絕對不可能。暫時把SunSpider的benchmark上的問題和CPU計算密集型的問題都拋開,我們可以得出這樣的結論:JavaScript,盡管現在存在著,是和移動平臺軟件開發過程中絕對重要的思想,即永遠要考慮內存問題,從根本上是背道而馳的

只要人們想要人們想在移動設備上開發各種視頻和照片處理程序(不像桌面電腦),只要移動設備的內存不是那么充足,這個問題就是非常棘手的。你在移動設備上需要理性的、正式的內存管理保證。而JavaScript從設計上來說是拒絕提供這些的

假設它能夠提供這些

現在你可能會問,“OK,桌面環境上的JS開發者不會移動設備上的開發者遇到的問題。假設他們相信你說的,或者假設有一些知道這些問題的移動開發者們根據JS重新設計一門語言。你感覺理論上他們可以做哪些事情?”

我不確定這是否是解決的,但是我可以在這個問題上放一些邊界。有另一群人曾經嘗試在JS的基礎上設計一門適合移動開發者的語言——RubyMotion。

這些人非常聰明,他們很了解Ruby。然后這些Ruby開發者認為垃圾回收對于他們的語言來說是一個糟糕的想法。(GC倡導者們,你們看到我說的了嗎?)所以他們用了一種非常類似ARC的技術然后嫁接到語言當中,然而卻沒有成功。

總結:很多人正經歷著由于RM-3或者其它難以辨別的問題所導致的內存相關議題,我們可以看看他們怎么說。

Ben Sheldon說:

不僅僅是你,我也面臨著內存相關的程序崩潰(比如SIGSEGV和SIGBUS)生產環境下有10-20%的用戶遇到過這種情況。

有一些人懷疑這個問題是否易于處理:

我在最近的一次Motion Meetup會上提出關于RM-3的問題,Laurent和Watson都對此提出了自己的看法。Watson提到說,RM-3是最難修復的bug;Laurent說他嘗試了很多方法,但最終都沒有很好地解決這個問題。他們兩個人都是非常聰明和厲害的程序員,所以我相信他們說的話。

還有一些人懷疑編譯器理論上是否能夠解決這個問題:

很長的一段時間內,我都認為編譯器可以簡單明確地處理程序塊,即靜態地分析程序塊內部的內容來判斷程序塊是否引用了這個程序塊外部的變量。我認為,對于所有這些變量,編譯器可以在程序塊創建時獲取,在程序塊銷毀時釋放。這個過程吧這些變量的生命周期綁定到程序塊上(當然,在某種情況下不是“完整的”生命周期)。有一個問題是instance_eval(譯注:Ruby中Object類的方法)。程序塊中的內容或許是按你提前知道的方式使用的,但也有可能并不是你能夠提前知道的。

RubyMotion還有一個對立的問題:內存泄露,而且它還有可能有其它問題。沒有人真正知道程序崩潰時內存泄露有2個原因還是有200個原因。

所以不管怎么說,我們的結論是:一部分世界上最好的Ruby程序員專門為移動設備開發設計了一種語言,他們設計了一個系統,這個系統不僅會崩潰,而且還會內存泄露,這些問題都是你可能會面臨到的。至今為止他們并沒有能夠處理這個問題,盡管他們已經非常盡力了。對了,他們也表示他們“自己嘗試了不少次,但沒有能夠能夠找到一個好的并且能夠保持高性能的解決方案”。

我并不是說在JavaScript的基礎上創建一門具有較高內存性能的語言是不可能的,我只是想說很多證據顯示這個問題會非常難。

更新:一個Rust語言的貢獻者提到:

我為Rust項目工作,我的主要目標是實現零額外開銷的內存安全。我們通過“@-boxes”(@T聲明的類型是任何類型T)的方式來支持通過GC處理的對象,而我們最近遇到的比較麻煩的事情是,GC觸碰到語言中的所有內容。如果你想支持GC但卻不需要它,你就要非常仔細地設計你的怨言來支持零額外開銷的非GC指針。這不是一個簡單的問題,我不認為可以通過建立在JS的基礎上創建一門新語言來解決

OK,但是ASM.JS如何呢?

asm.js就比較有趣了,因為它提供了一個JavaScript模型,但這個模型嚴格意義上不是建立在垃圾回收的基礎上的。所以從理論上講,使用正確的網頁瀏覽器,使用正確的API就可以了。問題是,“我們會得到正確的瀏覽器嗎?”

Mozilla顯然在這個概念上被出賣了,作為這個技術的作者,他們的實現今年晚些時候實現了它。Chrome的反應一直是含糊不清的,因為這個技術顯然和Google的其它提案,包括Dart和PNaC1有直接的競爭關系。關于它有一個開發的bug清單,但是一個V8的黑客對此不滿意。至于Apple陣營,按照我現在看來,WebKit那群人對比完全保持沉默。IE?我從來就沒有抱任何希望。

無論如何,現在還不能說asm.js就是真正解決JavaScript問題,且能夠擊敗所有其它提案的方法。另外,如果它能做到,它真的不可能是JavaScript,畢竟它能夠可行的原因就是拋開了麻煩的垃圾回收器。所以它有可能和C/C++或者其它手動管理內存的語言的前端一起工作,但肯定不和我們現在知道并且喜歡的動態語言一樣。

相對什么來說慢?

當一些文章里面說“X慢”和“X不慢”的時候,一個問題是,沒有人真正說的清楚它們的參照系是什么。對于一個網頁瀏覽器開發者,和對于一個高性能集群的開發者,以及對于一個嵌入式系統的開發者,等等,“慢”的含義是不一樣的。既然我們已經闖過了戰壕而且做了這么多benchmark,我可以給出你三個有用大致正確坐標系

如果你是一個Web開發者,把iPhone 4S的Nitro當做IE8來看,因為它們的benchmark成績差不多。這就給了你寫代碼時的正確坐標系。寫代碼的時候應該謹慎地使用JS,否則你會面臨一大堆平臺相關的性能問題要處理。有些應用用JS來寫性價比是不高的,即使是流行的瀏覽器。

如果你是x86平臺上的C/C++開發者,把iPhone 4S的Web開發環境當成只有桌面開發環境性能的1/50。其中1/10來自于ARM相對于x86的性能差距,1/5來自于JavaScript相對于C/C++的性能差距。在非JavaScript、性能為桌面環境1/10的情況下,仔細考慮正反面的因素。

如果你是Java、Ruby、Python或者C#開發者,按照以下方式去理解iPhone 4S的Web開發環境:它的性能是你電腦的1/10(ARM的因素),并且如果你的內存使用超過35M,性能會指數級下降,這是由垃圾回收的工作方式決定的。還有,如果你的程序分配了超過213M的內存,程序就會崩潰。注意,沒有人“從設計的角度”在運行時刻給你這個信息。對了,人們都希望你在這種環境下寫出很耗內存的照片處理和視頻應用。

這是一篇非常長的文章

下面是你應該記得的內容:

  • 2013年,用JavaScript寫的移動應用(如照片編輯等)實在是太慢了。
    • 比原生代碼慢5倍
    • 性能和IE差不多
    • 比x86平臺上的C/C++代碼慢50倍
    • 如果你的程序所有的內存不超過35M,比服務器端的Java/Ruby/Python/C#慢10倍;如果內存使用超過這個數,性能開始指數級下降
  • 要使這個速度變得快一些,最可能的方式是讓硬件性能達到桌面水平的性能。從長遠來看這是可行的,但是看起來要等很長時間。
  • 最近一段時間JavaScript語言本身并沒有變得更快,在JavaScript上工作的人認為,在現有的語言和API下,它永遠不會向原生代碼那么快。
  • 垃圾回收在內存受限的環境下會呈現指數級的性能下降,這一點比桌面和服務器級別的情況差很多。
  • 任何能干的移動開發者都花很多時間來為目標設備考慮內存性能問題,不管他們是否使用具有GC的環境。
  • 當前的JavaScript,從本質上是和允許程序為目標設備考慮內存性能問題這一點背道而馳的。
  • 如果JavaScript的工作者們意識到這問題并且做出改變,允許開發者考慮內存問題,經驗表明這是技術上的難題。
  • asm.js讓人看到了一些希望,但是就算它能成功,它應該是用了C/C++或者類似的“過時的”語言的前端,而不是像JavaScript這樣的前端。

讓我們提高爭論的層次

毫無疑問的一點是,我不久就將收到上百封郵件,這些郵件圈出我說的某句話,然后在不提供任何實際的證據(或者根本不能算是證據)的情況下,指出我說得不對。或者說“我曾經用JavaScript寫過一個文本編輯器,挺好”,或者說“有些我從來沒見過的人寫了一個飛行模擬器,但是從來沒有給我寫郵件說明他們遇到性能問題”,這些郵件我會一律刪除。

如果我們想要在移動Web開發(或者是原生應用,或者是任何其它事情)上取得一些進展,我們都需要各種至少看上去有說服力(at least appear to have a plausible basis)的討論,包括benchmark、期刊以及編譯器作者們的引用等等。網上有很多HN關于“我曾經寫了一個Web應用,挺好”的評論,還有很多關于Facebook在知道他們將會知道現在應該知道的東西的情況下(譯注:原味knowing what they would have known then what they could have known now,不知這樣翻譯對不對?)是選擇HTML5還是原生應用是對是錯的爭論(譯注:原文為bikeshedding,這是一個比較有意思的詞,意思是在還沒完成自行車車架還沒弄好的情況下就去討論車的顏色,意指過于關心細節和邊緣的問題,而忽視主要問題)。

對于我們來說,剩下來的任務是,明確地量化如何使得移動Web和原生生態環境變得越來越好,接著為此做出一些事情。正如你所知,這也是一個軟件開發者應該做的事情。

轉載于:https://www.cnblogs.com/beesky520/p/4843631.html

總結

以上是生活随笔為你收集整理的201509281125_《为什么移动app会很慢的深度分析(摘自司徒正美博客园文章)》的全部內容,希望文章能夠幫你解決所遇到的問題。

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

丁香花在线影院观看在线播放 | 国产精品无码一区二区桃花视频 | 性欧美大战久久久久久久 | 亚洲a无码综合a国产av中文 | 夜精品a片一区二区三区无码白浆 | 国产人妻人伦精品1国产丝袜 | 美女扒开屁股让男人桶 | 中文字幕久久久久人妻 | 大肉大捧一进一出视频出来呀 | 日本精品少妇一区二区三区 | 人妻aⅴ无码一区二区三区 | 秋霞成人午夜鲁丝一区二区三区 | 男女爱爱好爽视频免费看 | 欧美丰满熟妇xxxx性ppx人交 | 国产熟妇另类久久久久 | 久久久久久亚洲精品a片成人 | 国产亚洲精品久久久久久大师 | 粗大的内捧猛烈进出视频 | 色欲人妻aaaaaaa无码 | 成人影院yy111111在线观看 | 亚洲精品综合一区二区三区在线 | 日日干夜夜干 | 荡女精品导航 | 亚洲人成人无码网www国产 | 久久久久国色av免费观看性色 | 又粗又大又硬又长又爽 | 人妻与老人中文字幕 | 国产av人人夜夜澡人人爽麻豆 | 国产区女主播在线观看 | 中文字幕av伊人av无码av | 欧洲欧美人成视频在线 | 伦伦影院午夜理论片 | 999久久久国产精品消防器材 | 国产色视频一区二区三区 | 国产精品毛片一区二区 | 55夜色66夜色国产精品视频 | 国产精品欧美成人 | 精品aⅴ一区二区三区 | 亚洲无人区一区二区三区 | 欧美午夜特黄aaaaaa片 | 国产成人一区二区三区别 | √8天堂资源地址中文在线 | 精品国产一区二区三区av 性色 | 亚洲色大成网站www | 成人免费无码大片a毛片 | 福利一区二区三区视频在线观看 | 伊人久久婷婷五月综合97色 | 亚洲国产精华液网站w | 国产午夜精品一区二区三区嫩草 | 欧洲vodafone精品性 | 精品日本一区二区三区在线观看 | 无码人妻久久一区二区三区不卡 | 夜夜高潮次次欢爽av女 | 麻豆果冻传媒2021精品传媒一区下载 | av无码电影一区二区三区 | 免费看少妇作爱视频 | 国产精品嫩草久久久久 | 久久精品人妻少妇一区二区三区 | 欧美精品无码一区二区三区 | 激情五月综合色婷婷一区二区 | 日韩人妻无码中文字幕视频 | 日本va欧美va欧美va精品 | 国内精品久久毛片一区二区 | 香蕉久久久久久av成人 | 午夜免费福利小电影 | 日日摸日日碰夜夜爽av | 色综合久久久久综合一本到桃花网 | 中文字幕av无码一区二区三区电影 | 亚洲码国产精品高潮在线 | 精品一区二区三区无码免费视频 | 黑人巨大精品欧美一区二区 | 国产99久久精品一区二区 | 日韩人妻无码一区二区三区久久99 | 精品国产福利一区二区 | 无码免费一区二区三区 | 夜夜影院未满十八勿进 | 无码一区二区三区在线观看 | 老熟女重囗味hdxx69 | 久久久国产精品无码免费专区 | 久久综合九色综合欧美狠狠 | 国内精品久久毛片一区二区 | 亚洲另类伦春色综合小说 | 麻豆国产97在线 | 欧洲 | 久久综合香蕉国产蜜臀av | 国产午夜福利亚洲第一 | 久久久精品成人免费观看 | 思思久久99热只有频精品66 | 99久久久无码国产精品免费 | 在线亚洲高清揄拍自拍一品区 | 国产精品高潮呻吟av久久4虎 | 国产sm调教视频在线观看 | 亚洲精品国产a久久久久久 | 欧美精品一区二区精品久久 | 久久综合九色综合欧美狠狠 | 国产精品亚洲а∨无码播放麻豆 | 2020最新国产自产精品 | 啦啦啦www在线观看免费视频 | 亚洲aⅴ无码成人网站国产app | 久久久av男人的天堂 | 丰满人妻一区二区三区免费视频 | 亚洲综合在线一区二区三区 | 成人欧美一区二区三区 | 中文无码伦av中文字幕 | 一本久久伊人热热精品中文字幕 | 精品久久久无码人妻字幂 | 婷婷丁香六月激情综合啪 | 国产午夜无码视频在线观看 | 国产精品久久久 | 日本丰满熟妇videos | 九月婷婷人人澡人人添人人爽 | 精品人人妻人人澡人人爽人人 | 无码人妻精品一区二区三区下载 | 少妇愉情理伦片bd | 国产香蕉97碰碰久久人人 | 激情内射日本一区二区三区 | 99精品国产综合久久久久五月天 | 亚洲熟妇色xxxxx亚洲 | 国内精品九九久久久精品 | 欧美性生交xxxxx久久久 | 日本免费一区二区三区最新 | 亚洲第一无码av无码专区 | 国产精品亚洲综合色区韩国 | 日本精品高清一区二区 | 无码免费一区二区三区 | 亚洲国产精品久久久天堂 | 露脸叫床粗话东北少妇 | 国产精品久久久久无码av色戒 | 国产精品免费大片 | 精品国产一区二区三区av 性色 | 免费看男女做好爽好硬视频 | 久久国产36精品色熟妇 | 精品久久久无码中文字幕 | 亚洲国产午夜精品理论片 | 国产亚洲美女精品久久久2020 | 麻花豆传媒剧国产免费mv在线 | 久久人人爽人人爽人人片ⅴ | 一本久久a久久精品vr综合 | 亚洲中文字幕无码一久久区 | 无码国产激情在线观看 | 美女黄网站人色视频免费国产 | 免费无码午夜福利片69 | 青春草在线视频免费观看 | 99在线 | 亚洲 | 对白脏话肉麻粗话av | 亚洲区小说区激情区图片区 | 无码国产乱人伦偷精品视频 | 亚洲国产精品久久人人爱 | 国产猛烈高潮尖叫视频免费 | 粉嫩少妇内射浓精videos | 欧美熟妇另类久久久久久不卡 | 亚洲国产欧美在线成人 | 亚洲色欲色欲欲www在线 | 亚洲欧美日韩国产精品一区二区 | 水蜜桃色314在线观看 | 日韩欧美成人免费观看 | 亚洲欧美精品伊人久久 | 日日噜噜噜噜夜夜爽亚洲精品 | 国産精品久久久久久久 | 国产三级精品三级男人的天堂 | 香蕉久久久久久av成人 | 欧美亚洲日韩国产人成在线播放 | 亚洲色在线无码国产精品不卡 | 黑人巨大精品欧美一区二区 | 大肉大捧一进一出好爽视频 | 成熟女人特级毛片www免费 | 日本熟妇浓毛 | 精品人人妻人人澡人人爽人人 | 精品久久综合1区2区3区激情 | www成人国产高清内射 | 国产精品无码成人午夜电影 | 国产日产欧产精品精品app | 国产又爽又黄又刺激的视频 | aⅴ在线视频男人的天堂 | 青青草原综合久久大伊人精品 | 岛国片人妻三上悠亚 | 理论片87福利理论电影 | 波多野结衣aⅴ在线 | 久久aⅴ免费观看 | 国产真实乱对白精彩久久 | 波多野结衣av一区二区全免费观看 | 精品久久久无码人妻字幂 | 亚洲色www成人永久网址 | 国产亚av手机在线观看 | 麻豆人妻少妇精品无码专区 | 国产精品怡红院永久免费 | 成人动漫在线观看 | 丰满人妻被黑人猛烈进入 | 在线观看欧美一区二区三区 | 国产无遮挡又黄又爽免费视频 | 国产在线精品一区二区三区直播 | 国产精品怡红院永久免费 | 中文字幕无码热在线视频 | 波多野结衣av一区二区全免费观看 | 蜜桃臀无码内射一区二区三区 | 欧美精品免费观看二区 | 亚洲日本一区二区三区在线 | 九九热爱视频精品 | 国精产品一品二品国精品69xx | 97夜夜澡人人爽人人喊中国片 | 久久久久久久人妻无码中文字幕爆 | 亚洲精品国偷拍自产在线麻豆 | 欧美日韩在线亚洲综合国产人 | 午夜免费福利小电影 | 7777奇米四色成人眼影 | 欧美国产日韩亚洲中文 | 国产一区二区三区四区五区加勒比 | 在线看片无码永久免费视频 | 东京一本一道一二三区 | 荡女精品导航 | 十八禁视频网站在线观看 | 99久久精品日本一区二区免费 | 欧美丰满老熟妇xxxxx性 | 久久久婷婷五月亚洲97号色 | 国产一区二区三区影院 | 天堂亚洲免费视频 | 无码毛片视频一区二区本码 | 中文字幕人妻无码一区二区三区 | 国产小呦泬泬99精品 | 欧美喷潮久久久xxxxx | 人妻夜夜爽天天爽三区 | 亚洲国产精品无码久久久久高潮 | 色诱久久久久综合网ywww | av香港经典三级级 在线 | 欧美精品免费观看二区 | 国产人妻人伦精品1国产丝袜 | 人妻少妇精品视频专区 | 76少妇精品导航 | 久久久av男人的天堂 | 国产一区二区三区四区五区加勒比 | 亚洲午夜福利在线观看 | 人妻插b视频一区二区三区 | 天堂无码人妻精品一区二区三区 | 精品一区二区不卡无码av | 奇米影视7777久久精品 | 色噜噜亚洲男人的天堂 | 亚洲日本一区二区三区在线 | √天堂资源地址中文在线 | 无码乱肉视频免费大全合集 | 免费人成在线视频无码 | 风流少妇按摩来高潮 | 欧美精品国产综合久久 | 亚洲一区av无码专区在线观看 | 综合网日日天干夜夜久久 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲色欲久久久综合网东京热 | 免费视频欧美无人区码 | 日本va欧美va欧美va精品 | 久久 国产 尿 小便 嘘嘘 | 国产精品二区一区二区aⅴ污介绍 | 在线 国产 欧美 亚洲 天堂 | 日本肉体xxxx裸交 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产一区二区三区四区五区加勒比 | 狠狠综合久久久久综合网 | 日本一区二区更新不卡 | 欧美精品无码一区二区三区 | 亚洲成熟女人毛毛耸耸多 | www国产精品内射老师 | 纯爱无遮挡h肉动漫在线播放 | 国产超碰人人爽人人做人人添 | 久久久久av无码免费网 | 麻豆md0077饥渴少妇 | 久久久久国色av免费观看性色 | 国产亚洲欧美在线专区 | 久久人人爽人人爽人人片ⅴ | 激情亚洲一区国产精品 | 中文字幕色婷婷在线视频 | 中文字幕无码日韩欧毛 | 爱做久久久久久 | 国产特级毛片aaaaaaa高清 | 高清无码午夜福利视频 | 国产亚洲欧美日韩亚洲中文色 | 捆绑白丝粉色jk震动捧喷白浆 | 乌克兰少妇性做爰 | 99久久99久久免费精品蜜桃 | 免费无码午夜福利片69 | 久精品国产欧美亚洲色aⅴ大片 | 午夜福利一区二区三区在线观看 | 精品久久久中文字幕人妻 | 亚洲精品国偷拍自产在线麻豆 | 老子影院午夜精品无码 | 国内揄拍国内精品人妻 | 装睡被陌生人摸出水好爽 | 国产亚洲欧美日韩亚洲中文色 | 动漫av网站免费观看 | 中文字幕无码av波多野吉衣 | 亚洲一区二区三区香蕉 | 人妻尝试又大又粗久久 | 99久久无码一区人妻 | 国产午夜无码精品免费看 | 亚洲高清偷拍一区二区三区 | 大乳丰满人妻中文字幕日本 | 国产莉萝无码av在线播放 | 99精品久久毛片a片 | 熟妇女人妻丰满少妇中文字幕 | 亚洲综合久久一区二区 | 亚洲日本va中文字幕 | 色欲久久久天天天综合网精品 | 国产 精品 自在自线 | 国产成人无码av片在线观看不卡 | 麻豆md0077饥渴少妇 | 亚洲の无码国产の无码影院 | 欧美人与物videos另类 | 久久亚洲日韩精品一区二区三区 | 国产农村乱对白刺激视频 | 久久99久久99精品中文字幕 | 国产乱子伦视频在线播放 | 免费乱码人妻系列无码专区 | 曰本女人与公拘交酡免费视频 | 男女作爱免费网站 | 无码av中文字幕免费放 | 国产麻豆精品精东影业av网站 | 亚洲日韩av一区二区三区四区 | 四虎国产精品免费久久 | 国产欧美精品一区二区三区 | 高潮喷水的毛片 | 国产精品亚洲五月天高清 | 久久午夜夜伦鲁鲁片无码免费 | 国产成人无码av片在线观看不卡 | 欧美亚洲国产一区二区三区 | 日韩亚洲欧美中文高清在线 | 亚洲 a v无 码免 费 成 人 a v | 亚洲熟妇色xxxxx欧美老妇y | 精品偷拍一区二区三区在线看 | 国产黑色丝袜在线播放 | 中文字幕 亚洲精品 第1页 | 国产亚洲精品久久久ai换 | 中文精品久久久久人妻不卡 | 大屁股大乳丰满人妻 | 亚洲国产精品一区二区美利坚 | 老司机亚洲精品影院 | 奇米影视888欧美在线观看 | 曰韩无码二三区中文字幕 | 精品国产国产综合精品 | 亚洲精品久久久久久久久久久 | 亚洲色大成网站www国产 | 久青草影院在线观看国产 | 亚洲熟悉妇女xxx妇女av | 亚洲娇小与黑人巨大交 | 粗大的内捧猛烈进出视频 | 精品人人妻人人澡人人爽人人 | 亚洲 另类 在线 欧美 制服 | 亚洲成a人片在线观看无码3d | 六十路熟妇乱子伦 | 国产精品久久久久久久影院 | 国产午夜福利100集发布 | 老司机亚洲精品影院无码 | 麻豆果冻传媒2021精品传媒一区下载 | 蜜桃臀无码内射一区二区三区 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲中文字幕无码一久久区 | 日日天干夜夜狠狠爱 | 97精品国产97久久久久久免费 | 国产精品毛多多水多 | 色婷婷综合激情综在线播放 | 中国女人内谢69xxxxxa片 | 久久久久久九九精品久 | 九九综合va免费看 | 日本丰满护士爆乳xxxx | 少妇厨房愉情理9仑片视频 | 亚洲自偷精品视频自拍 | 日本丰满护士爆乳xxxx | 亚洲s色大片在线观看 | 人人澡人人透人人爽 | 午夜熟女插插xx免费视频 | 白嫩日本少妇做爰 | 国产精品久久久久7777 | 荫蒂被男人添的好舒服爽免费视频 | 日本精品人妻无码77777 天堂一区人妻无码 | 日本丰满熟妇videos | 大乳丰满人妻中文字幕日本 | 久久久久久九九精品久 | 大乳丰满人妻中文字幕日本 | 欧美高清在线精品一区 | 又大又黄又粗又爽的免费视频 | av人摸人人人澡人人超碰下载 | 色婷婷欧美在线播放内射 | 国产人妻大战黑人第1集 | 欧美一区二区三区 | 国产精品办公室沙发 | 免费观看黄网站 | 国产乱人伦av在线无码 | 男女超爽视频免费播放 | 日日天干夜夜狠狠爱 | 中国女人内谢69xxxxxa片 | 久久国产精品_国产精品 | 少妇人妻偷人精品无码视频 | 四十如虎的丰满熟妇啪啪 | 久久精品国产99精品亚洲 | 午夜肉伦伦影院 | 亚洲中文字幕无码一久久区 | 亚洲人交乣女bbw | 国产三级久久久精品麻豆三级 | 久久久久久亚洲精品a片成人 | 少妇人妻av毛片在线看 | 伊人久久大香线蕉亚洲 | 国产熟女一区二区三区四区五区 | 国产成人精品无码播放 | 国产熟妇另类久久久久 | 国产乱码精品一品二品 | 人人爽人人澡人人人妻 | 国产欧美精品一区二区三区 | 老熟女重囗味hdxx69 | 国产人妻大战黑人第1集 | 国产精品久久久久9999小说 | 亚洲中文字幕va福利 | 亚洲欧美精品伊人久久 | 精品久久久中文字幕人妻 | 日产精品99久久久久久 | 岛国片人妻三上悠亚 | 亚洲码国产精品高潮在线 | 夜夜躁日日躁狠狠久久av | 亚洲无人区午夜福利码高清完整版 | 又粗又大又硬毛片免费看 | 东京无码熟妇人妻av在线网址 | 国产精品无码成人午夜电影 | 性做久久久久久久免费看 | 1000部夫妻午夜免费 | 精品无码国产自产拍在线观看蜜 | 亚洲欧美日韩国产精品一区二区 | 波多野结衣高清一区二区三区 | 成人亚洲精品久久久久软件 | 国产精品无码一区二区桃花视频 | 久久aⅴ免费观看 | 亚洲综合色区中文字幕 | 成人精品视频一区二区 | 中文字幕日韩精品一区二区三区 | 麻豆蜜桃av蜜臀av色欲av | 人妻熟女一区 | 国产亚洲tv在线观看 | 亚洲日本va中文字幕 | 无码人妻丰满熟妇区五十路百度 | 乱人伦人妻中文字幕无码久久网 | 中文字幕+乱码+中文字幕一区 | 亚洲色欲色欲天天天www | 国产亚洲精品久久久久久 | 亚洲成在人网站无码天堂 | 国产人妖乱国产精品人妖 | 99精品久久毛片a片 | 精品国产麻豆免费人成网站 | 波多野结衣av一区二区全免费观看 | 黑人巨大精品欧美黑寡妇 | 麻花豆传媒剧国产免费mv在线 | 中文字幕日产无线码一区 | 国产激情无码一区二区app | 九九综合va免费看 | 水蜜桃色314在线观看 | 国产香蕉尹人综合在线观看 | 国产偷自视频区视频 | 日本一卡2卡3卡四卡精品网站 | 男人和女人高潮免费网站 | 国产精品人妻一区二区三区四 | 妺妺窝人体色www婷婷 | 欧美人与物videos另类 | 又粗又大又硬又长又爽 | 丰满肥臀大屁股熟妇激情视频 | 久久国产精品萌白酱免费 | 亚洲国产av精品一区二区蜜芽 | 精品国精品国产自在久国产87 | 亚洲第一网站男人都懂 | 久久久精品456亚洲影院 | 欧美日韩精品 | 毛片内射-百度 | 97人妻精品一区二区三区 | 男人的天堂av网站 | 大肉大捧一进一出好爽视频 | 在线精品亚洲一区二区 | 欧美野外疯狂做受xxxx高潮 | 日韩精品一区二区av在线 | 波多野结衣av一区二区全免费观看 | 成人欧美一区二区三区 | 日本一卡2卡3卡四卡精品网站 | 四虎国产精品免费久久 | 四虎永久在线精品免费网址 | 国产成人无码午夜视频在线观看 | 久久久久久a亚洲欧洲av冫 | 欧美午夜特黄aaaaaa片 | 亚洲欧洲无卡二区视頻 | 欧美人与动性行为视频 | 人妻插b视频一区二区三区 | 亚洲天堂2017无码中文 | 精品无人国产偷自产在线 | 国产一区二区三区精品视频 | 亚洲色成人中文字幕网站 | 国产午夜视频在线观看 | 亚拍精品一区二区三区探花 | 国内精品人妻无码久久久影院蜜桃 | 欧美日韩亚洲国产精品 | 性啪啪chinese东北女人 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国产在线无码精品电影网 | 国产成人综合在线女婷五月99播放 | 国产熟妇另类久久久久 | 欧美激情综合亚洲一二区 | 国产又粗又硬又大爽黄老大爷视 | 狠狠cao日日穞夜夜穞av | 好屌草这里只有精品 | 欧美亚洲国产一区二区三区 | 欧美激情内射喷水高潮 | 日韩人妻无码中文字幕视频 | 中文字幕无码免费久久9一区9 | 亚洲国产精品美女久久久久 | 无码国内精品人妻少妇 | 黑人粗大猛烈进出高潮视频 | 国产明星裸体无码xxxx视频 | a国产一区二区免费入口 | 又粗又大又硬又长又爽 | 欧美激情综合亚洲一二区 | 成人动漫在线观看 | 十八禁真人啪啪免费网站 | 人妻与老人中文字幕 | 日本精品久久久久中文字幕 | 国产人妻人伦精品1国产丝袜 | 麻豆蜜桃av蜜臀av色欲av | 国产成人综合色在线观看网站 | 国内丰满熟女出轨videos | 麻豆md0077饥渴少妇 | 无码一区二区三区在线 | 无码帝国www无码专区色综合 | 夜夜躁日日躁狠狠久久av | 全黄性性激高免费视频 | 久久久久99精品成人片 | 正在播放东北夫妻内射 | 国产午夜福利100集发布 | 一本大道久久东京热无码av | 永久免费观看美女裸体的网站 | 特黄特色大片免费播放器图片 | 免费观看又污又黄的网站 | 成人免费视频视频在线观看 免费 | 国产精品无码一区二区三区不卡 | www国产亚洲精品久久网站 | 亚洲七七久久桃花影院 | 国产在线无码精品电影网 | 四虎永久在线精品免费网址 | 亚洲综合在线一区二区三区 | 女高中生第一次破苞av | 300部国产真实乱 | 青青草原综合久久大伊人精品 | 波多野结衣高清一区二区三区 | 中国女人内谢69xxxxxa片 | 大地资源中文第3页 | 亚洲国产日韩a在线播放 | 四虎国产精品一区二区 | 国产香蕉尹人视频在线 | 麻花豆传媒剧国产免费mv在线 | 精品国产aⅴ无码一区二区 | 精品无码一区二区三区爱欲 | 99久久99久久免费精品蜜桃 | 国产网红无码精品视频 | 日本一区二区三区免费高清 | 精品国产青草久久久久福利 | 高潮喷水的毛片 | 精品国产精品久久一区免费式 | 久久99久久99精品中文字幕 | 国产精品久久久一区二区三区 | 扒开双腿吃奶呻吟做受视频 | 无码人妻丰满熟妇区五十路百度 | 亚洲经典千人经典日产 | 亚洲 高清 成人 动漫 | 精品亚洲成av人在线观看 | 精品午夜福利在线观看 | 国产精品无码久久av | 国产午夜手机精彩视频 | 国产精品人人妻人人爽 | 久久无码专区国产精品s | 爽爽影院免费观看 | 日韩视频 中文字幕 视频一区 | 亚洲成av人在线观看网址 | 狠狠亚洲超碰狼人久久 | 大地资源中文第3页 | 亚洲精品久久久久中文第一幕 | 少妇厨房愉情理9仑片视频 | 久久久精品456亚洲影院 | 丰满肥臀大屁股熟妇激情视频 | 久久视频在线观看精品 | 国产精品久久久 | 任你躁在线精品免费 | 一本久久伊人热热精品中文字幕 | 国产深夜福利视频在线 | 欧洲欧美人成视频在线 | 国产香蕉尹人视频在线 | 少妇被黑人到高潮喷出白浆 | 久久无码专区国产精品s | 性生交大片免费看女人按摩摩 | 日韩人妻少妇一区二区三区 | 成人影院yy111111在线观看 | 欧美性黑人极品hd | 97人妻精品一区二区三区 | 激情国产av做激情国产爱 | 亚洲天堂2017无码 | 美女扒开屁股让男人桶 | 女人被爽到呻吟gif动态图视看 | 乱人伦人妻中文字幕无码久久网 | 亚洲欧美日韩国产精品一区二区 | 精品厕所偷拍各类美女tp嘘嘘 | 色五月五月丁香亚洲综合网 | 自拍偷自拍亚洲精品被多人伦好爽 | 免费乱码人妻系列无码专区 | 色综合久久88色综合天天 | 999久久久国产精品消防器材 | 亚洲国产精品久久久天堂 | 无码吃奶揉捏奶头高潮视频 | 无码免费一区二区三区 | 成人欧美一区二区三区黑人免费 | 国产精品久久久久久无码 | 一本精品99久久精品77 | 在教室伦流澡到高潮hnp视频 | 亚洲人成网站在线播放942 | 奇米影视888欧美在线观看 | 亚洲午夜久久久影院 | 国产高潮视频在线观看 | 日韩欧美群交p片內射中文 | 日本护士毛茸茸高潮 | 国产人妻精品一区二区三区不卡 | 国产无套内射久久久国产 | 国产高潮视频在线观看 | 欧美喷潮久久久xxxxx | 在线看片无码永久免费视频 | 在线а√天堂中文官网 | 少妇性l交大片欧洲热妇乱xxx | 国产成人一区二区三区在线观看 | 97人妻精品一区二区三区 | 国产区女主播在线观看 | 国产人妻大战黑人第1集 | 欧美黑人性暴力猛交喷水 | 九九在线中文字幕无码 | 亚洲乱码日产精品bd | 国产亲子乱弄免费视频 | 久久久www成人免费毛片 | 欧美人妻一区二区三区 | 久久久久av无码免费网 | 色综合久久网 | 成年美女黄网站色大免费全看 | 熟女俱乐部五十路六十路av | 日韩精品无码免费一区二区三区 | 欧美人妻一区二区三区 | 国产免费观看黄av片 | 丰满少妇高潮惨叫视频 | 人人妻人人澡人人爽人人精品 | 精品国产精品久久一区免费式 | 强开小婷嫩苞又嫩又紧视频 | 成人综合网亚洲伊人 | 国产av无码专区亚洲a∨毛片 | 精品亚洲成av人在线观看 | 一区二区传媒有限公司 | 日韩人妻系列无码专区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 无码毛片视频一区二区本码 | 麻豆国产丝袜白领秘书在线观看 | 国产猛烈高潮尖叫视频免费 | 国产在线aaa片一区二区99 | 精品久久久久久亚洲精品 | 国产av人人夜夜澡人人爽麻豆 | 成人毛片一区二区 | 无码中文字幕色专区 | 小鲜肉自慰网站xnxx | 老头边吃奶边弄进去呻吟 | 娇妻被黑人粗大高潮白浆 | 乱码av麻豆丝袜熟女系列 | 国产农村乱对白刺激视频 | 黑森林福利视频导航 | 在线a亚洲视频播放在线观看 | 国产av一区二区精品久久凹凸 | 丰满少妇熟乱xxxxx视频 | 精品久久久久久人妻无码中文字幕 | 中文字幕人妻丝袜二区 | 国产福利视频一区二区 | 亚洲精品一区国产 | 色老头在线一区二区三区 | 55夜色66夜色国产精品视频 | 人妻无码αv中文字幕久久琪琪布 | 中文字幕人妻无码一区二区三区 | 1000部啪啪未满十八勿入下载 | 无码乱肉视频免费大全合集 | 精品人人妻人人澡人人爽人人 | 国产精品亚洲а∨无码播放麻豆 | 在线观看国产午夜福利片 | 国产激情综合五月久久 | 对白脏话肉麻粗话av | 免费乱码人妻系列无码专区 | 亚洲成av人综合在线观看 | 六十路熟妇乱子伦 | 欧美日韩一区二区免费视频 | 精品成人av一区二区三区 | 亚洲欧洲无卡二区视頻 | 天堂无码人妻精品一区二区三区 | 国产精品资源一区二区 | 人妻少妇被猛烈进入中文字幕 | 亚洲熟熟妇xxxx | www一区二区www免费 | 亚洲中文字幕无码中字 | 九九在线中文字幕无码 | 久9re热视频这里只有精品 | 鲁一鲁av2019在线 | 国产精品人妻一区二区三区四 | 欧美人与动性行为视频 | 国产精品亚洲一区二区三区喷水 | 久久久国产精品无码免费专区 | 51国偷自产一区二区三区 | 狠狠综合久久久久综合网 | 日日摸日日碰夜夜爽av | 性啪啪chinese东北女人 | 久久99热只有频精品8 | 99久久精品无码一区二区毛片 | 国产成人无码午夜视频在线观看 | 国内揄拍国内精品人妻 | 偷窥村妇洗澡毛毛多 | 欧美怡红院免费全部视频 | av在线亚洲欧洲日产一区二区 | 中文字幕无码视频专区 | 日本精品高清一区二区 | 精品久久久无码人妻字幂 | 人妻中文无码久热丝袜 | 精品国产一区二区三区四区在线看 | 亚洲 高清 成人 动漫 | 国产成人综合在线女婷五月99播放 | 未满成年国产在线观看 | 国产后入清纯学生妹 | 欧美日本精品一区二区三区 | 无码精品人妻一区二区三区av | 久久久久se色偷偷亚洲精品av | 亚洲天堂2017无码中文 | 久久久久成人片免费观看蜜芽 | 曰本女人与公拘交酡免费视频 | 秋霞成人午夜鲁丝一区二区三区 | 高中生自慰www网站 | 色综合久久久无码中文字幕 | 熟妇人妻无乱码中文字幕 | 狠狠cao日日穞夜夜穞av | 日韩精品成人一区二区三区 | 一本加勒比波多野结衣 | 亚洲va欧美va天堂v国产综合 | 蜜桃视频韩日免费播放 | 青青草原综合久久大伊人精品 | 国产卡一卡二卡三 | 一本久道久久综合婷婷五月 | 色五月五月丁香亚洲综合网 | 国产亚洲人成a在线v网站 | 纯爱无遮挡h肉动漫在线播放 | 鲁大师影院在线观看 | 欧美丰满熟妇xxxx性ppx人交 | 高清不卡一区二区三区 | 色婷婷综合激情综在线播放 | 极品嫩模高潮叫床 | aⅴ亚洲 日韩 色 图网站 播放 | 无码任你躁久久久久久久 | 呦交小u女精品视频 | 波多野结衣av一区二区全免费观看 | 精品久久久无码中文字幕 | 欧美日韩亚洲国产精品 | 亚洲а∨天堂久久精品2021 | 人妻与老人中文字幕 | 狠狠cao日日穞夜夜穞av | 久久久久av无码免费网 | 一本久道高清无码视频 | 亚洲成av人片在线观看无码不卡 | 国产精品人人爽人人做我的可爱 | 亚洲国产精品一区二区美利坚 | 亚洲精品一区二区三区大桥未久 | 亚洲 日韩 欧美 成人 在线观看 | 在线播放免费人成毛片乱码 | 无码av中文字幕免费放 | 久久99精品久久久久久动态图 | 岛国片人妻三上悠亚 | 欧美日韩视频无码一区二区三 | 青草视频在线播放 | 国产色在线 | 国产 | 无码毛片视频一区二区本码 | 国产成人一区二区三区别 | 精品aⅴ一区二区三区 | 久久精品国产一区二区三区肥胖 | 国产在线精品一区二区三区直播 | 久精品国产欧美亚洲色aⅴ大片 | 色欲人妻aaaaaaa无码 | 亚欧洲精品在线视频免费观看 | 综合激情五月综合激情五月激情1 | 樱花草在线播放免费中文 | 我要看www免费看插插视频 | 欧美老妇交乱视频在线观看 | 欧美高清在线精品一区 | 日韩人妻无码一区二区三区久久99 | ass日本丰满熟妇pics | 超碰97人人做人人爱少妇 | 国产人妻精品午夜福利免费 | 国产在线精品一区二区三区直播 | 东北女人啪啪对白 | 日本xxxx色视频在线观看免费 | 久久精品国产大片免费观看 | 色一情一乱一伦一区二区三欧美 | 亚洲性无码av中文字幕 | 欧美日韩综合一区二区三区 | 131美女爱做视频 | 国产精品丝袜黑色高跟鞋 | 人妻少妇精品无码专区动漫 | 亚洲熟悉妇女xxx妇女av | 久久国产精品二国产精品 | 国产麻豆精品精东影业av网站 | 美女极度色诱视频国产 | 国产精品美女久久久网av | 国产精品.xx视频.xxtv | 一个人免费观看的www视频 | 亚洲成av人片在线观看无码不卡 | 久久亚洲国产成人精品性色 | 婷婷丁香五月天综合东京热 | 夜夜躁日日躁狠狠久久av | 久久综合九色综合欧美狠狠 | 色欲综合久久中文字幕网 | 少妇无码av无码专区在线观看 | 成熟人妻av无码专区 | 欧美野外疯狂做受xxxx高潮 | 丰满妇女强制高潮18xxxx | 奇米影视888欧美在线观看 | 国产乱人伦偷精品视频 | 最近免费中文字幕中文高清百度 | 午夜精品一区二区三区的区别 | 亚洲日韩乱码中文无码蜜桃臀网站 | 18精品久久久无码午夜福利 | 国产亚洲人成a在线v网站 | 国产精品人人爽人人做我的可爱 | 国产在线精品一区二区高清不卡 | 国产精品va在线观看无码 | 无套内谢老熟女 | 亚洲精品中文字幕乱码 | 日本精品久久久久中文字幕 | 强伦人妻一区二区三区视频18 | аⅴ资源天堂资源库在线 | 国产成人精品久久亚洲高清不卡 | 国产成人无码一二三区视频 | 国产绳艺sm调教室论坛 | 麻豆国产97在线 | 欧洲 | 亚洲成a人片在线观看无码3d | 无码国产激情在线观看 | 欧洲熟妇精品视频 | 一本久道久久综合婷婷五月 | 色欲av亚洲一区无码少妇 | 成人精品天堂一区二区三区 | 国产精品亚洲а∨无码播放麻豆 | 激情内射亚州一区二区三区爱妻 | 亚洲色偷偷男人的天堂 | 人人爽人人澡人人人妻 | 动漫av一区二区在线观看 | 国产午夜无码精品免费看 | 老熟妇仑乱视频一区二区 | 国内少妇偷人精品视频 | 水蜜桃亚洲一二三四在线 | 99精品视频在线观看免费 | 免费人成在线视频无码 | 国内少妇偷人精品视频免费 | 全黄性性激高免费视频 | 亚洲精品国偷拍自产在线观看蜜桃 | 妺妺窝人体色www婷婷 | 中文字幕人妻无码一区二区三区 | 欧美35页视频在线观看 | 久久精品女人天堂av免费观看 | 欧美性猛交xxxx富婆 | 精品久久久无码人妻字幂 | 亚洲成av人片在线观看无码不卡 | 国产精品无码一区二区三区不卡 | 亚洲中文字幕无码中文字在线 | 中国女人内谢69xxxx | 欧美xxxx黑人又粗又长 | 久久久久国色av免费观看性色 | 精品久久久久久人妻无码中文字幕 | 久久久久久九九精品久 | 18禁止看的免费污网站 | 国产精品久久久久无码av色戒 | 3d动漫精品啪啪一区二区中 | 99er热精品视频 | 欧美freesex黑人又粗又大 | 中文字幕精品av一区二区五区 | 色综合久久88色综合天天 | 亚洲成av人片天堂网无码】 | 国产一区二区三区四区五区加勒比 | 极品嫩模高潮叫床 | 亚洲の无码国产の无码影院 | 亚拍精品一区二区三区探花 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 98国产精品综合一区二区三区 | 97无码免费人妻超级碰碰夜夜 | 亚洲小说图区综合在线 | 粗大的内捧猛烈进出视频 | 亚洲中文字幕无码中字 | 99精品久久毛片a片 | 国产乱人伦偷精品视频 | 久久天天躁夜夜躁狠狠 | 午夜精品久久久久久久久 | 免费无码一区二区三区蜜桃大 | 久久99精品久久久久婷婷 | 在教室伦流澡到高潮hnp视频 | 国产精品.xx视频.xxtv | 亚洲 a v无 码免 费 成 人 a v | 日韩av无码一区二区三区不卡 | 亚洲一区av无码专区在线观看 | 日韩精品无码一区二区中文字幕 | 人人妻人人澡人人爽欧美精品 | 欧美精品无码一区二区三区 | 成在人线av无码免观看麻豆 | 理论片87福利理论电影 | 久久精品女人天堂av免费观看 | 无码国产乱人伦偷精品视频 | 欧美肥老太牲交大战 | 性生交大片免费看女人按摩摩 | 日韩亚洲欧美中文高清在线 | 亚洲欧美精品aaaaaa片 | 成人欧美一区二区三区 | 国产三级精品三级男人的天堂 | 久久久久av无码免费网 | 狂野欧美性猛xxxx乱大交 | 色情久久久av熟女人妻网站 | 亚洲色在线无码国产精品不卡 | 免费观看又污又黄的网站 | 女人被爽到呻吟gif动态图视看 | 久久97精品久久久久久久不卡 | 国产亲子乱弄免费视频 | 欧美 日韩 人妻 高清 中文 | 国产超级va在线观看视频 | 国产特级毛片aaaaaaa高清 | 学生妹亚洲一区二区 | 一区二区传媒有限公司 | 久久无码专区国产精品s | 中文字幕色婷婷在线视频 | 久久久久久久久蜜桃 | 丝袜 中出 制服 人妻 美腿 | 丰满肥臀大屁股熟妇激情视频 | 免费国产成人高清在线观看网站 | 内射后入在线观看一区 | av人摸人人人澡人人超碰下载 | 欧美猛少妇色xxxxx | 成人性做爰aaa片免费看 | 亚洲欧美日韩成人高清在线一区 | 人人超人人超碰超国产 | 精品国产一区二区三区四区 | 国产精品毛多多水多 | 亚洲 高清 成人 动漫 | 久久午夜夜伦鲁鲁片无码免费 | 麻花豆传媒剧国产免费mv在线 | 丰满人妻被黑人猛烈进入 | 成人免费视频视频在线观看 免费 | 国产人成高清在线视频99最全资源 | 国产美女极度色诱视频www | 无码国模国产在线观看 | 久久久久99精品成人片 | 亚洲色偷偷偷综合网 | 久久精品中文闷骚内射 | 九月婷婷人人澡人人添人人爽 | 人人妻人人澡人人爽欧美一区 | 日本免费一区二区三区最新 | 俺去俺来也在线www色官网 | 亚洲综合色区中文字幕 | 99国产精品白浆在线观看免费 | 色综合久久88色综合天天 | 日日橹狠狠爱欧美视频 | 67194成是人免费无码 | 未满成年国产在线观看 | 欧美成人高清在线播放 | 蜜臀av无码人妻精品 | 成人精品一区二区三区中文字幕 | 内射老妇bbwx0c0ck | 亚洲va欧美va天堂v国产综合 | 亚洲熟熟妇xxxx | 国产 浪潮av性色四虎 | 日日麻批免费40分钟无码 | 领导边摸边吃奶边做爽在线观看 | 中文字幕人妻丝袜二区 | 国产九九九九九九九a片 | 亚欧洲精品在线视频免费观看 | 丰满护士巨好爽好大乳 | 久久国产精品精品国产色婷婷 | 综合网日日天干夜夜久久 | 中文字幕无码乱人伦 | 精品 日韩 国产 欧美 视频 | 欧美性黑人极品hd | 亚洲成色在线综合网站 | 成人性做爰aaa片免费看 | 两性色午夜视频免费播放 | 国精品人妻无码一区二区三区蜜柚 | 国产精品久久久久久久9999 | 丰满少妇人妻久久久久久 | 曰韩无码二三区中文字幕 | 99视频精品全部免费免费观看 | 一本加勒比波多野结衣 | 欧美日韩一区二区免费视频 | 人人妻人人澡人人爽人人精品 | 国产成人精品一区二区在线小狼 | 亚洲欧美精品伊人久久 | 久久成人a毛片免费观看网站 | 高潮毛片无遮挡高清免费 | 欧美国产亚洲日韩在线二区 | 久久综合香蕉国产蜜臀av | 久久综合色之久久综合 | 国产黑色丝袜在线播放 | 无码午夜成人1000部免费视频 | 国产精品国产三级国产专播 | 麻豆果冻传媒2021精品传媒一区下载 | 无码一区二区三区在线 | 天下第一社区视频www日本 | 国产口爆吞精在线视频 | 久久亚洲a片com人成 | 亚洲精品国产精品乱码视色 | 在线 国产 欧美 亚洲 天堂 | 一本精品99久久精品77 | 久久国内精品自在自线 | 亚洲一区二区三区四区 | 香蕉久久久久久av成人 | 天天拍夜夜添久久精品大 | 久久无码专区国产精品s | 人妻天天爽夜夜爽一区二区 | 国产亚洲精品久久久久久 | 中文精品久久久久人妻不卡 | 国产成人综合在线女婷五月99播放 | 国产黄在线观看免费观看不卡 | 婷婷色婷婷开心五月四房播播 | 欧美日韩色另类综合 | 久久久国产一区二区三区 | 国内少妇偷人精品视频 | 日韩亚洲欧美精品综合 | 久久午夜无码鲁丝片秋霞 | 精品熟女少妇av免费观看 | 久久精品国产日本波多野结衣 | 无遮无挡爽爽免费视频 | 日本成熟视频免费视频 | 国产精品二区一区二区aⅴ污介绍 | 精品一区二区不卡无码av | 欧洲极品少妇 | 国产真实乱对白精彩久久 | 久久国产自偷自偷免费一区调 | 亚洲国精产品一二二线 | 日韩人妻少妇一区二区三区 | 国产麻豆精品精东影业av网站 | 国产69精品久久久久app下载 | 久久综合给合久久狠狠狠97色 | 亚洲s码欧洲m码国产av | 亚洲自偷自偷在线制服 | 久久久久久久人妻无码中文字幕爆 | 久久综合色之久久综合 | 任你躁国产自任一区二区三区 | 久久国产自偷自偷免费一区调 | 国产精品无码一区二区桃花视频 | 人人妻人人澡人人爽人人精品浪潮 | 激情亚洲一区国产精品 | 风流少妇按摩来高潮 | 成 人 网 站国产免费观看 | 精品亚洲韩国一区二区三区 | 成 人 免费观看网站 | 国产av一区二区三区最新精品 | 六月丁香婷婷色狠狠久久 | 十八禁真人啪啪免费网站 | 免费网站看v片在线18禁无码 | 国产av剧情md精品麻豆 | 红桃av一区二区三区在线无码av | 伊人久久婷婷五月综合97色 | 午夜丰满少妇性开放视频 | 一个人免费观看的www视频 | 亚洲国产精品成人久久蜜臀 | 国产精品高潮呻吟av久久 | 性色av无码免费一区二区三区 | 日本欧美一区二区三区乱码 | 精品久久久无码中文字幕 | 无码午夜成人1000部免费视频 | 欧洲欧美人成视频在线 | 未满成年国产在线观看 | 久久久久99精品国产片 | 亚洲 另类 在线 欧美 制服 | 丰满妇女强制高潮18xxxx | 十八禁视频网站在线观看 | 小sao货水好多真紧h无码视频 | 欧洲欧美人成视频在线 | 成人欧美一区二区三区黑人免费 | 久久人人爽人人爽人人片av高清 | 日韩 欧美 动漫 国产 制服 | 欧美乱妇无乱码大黄a片 | 国产麻豆精品一区二区三区v视界 | 麻豆人妻少妇精品无码专区 | 国产精品无码一区二区三区不卡 | 日产精品99久久久久久 | 欧美 亚洲 国产 另类 | 亚洲自偷自拍另类第1页 | 亚洲中文字幕无码中字 | 乱码av麻豆丝袜熟女系列 | 精品久久久久香蕉网 | 天天躁日日躁狠狠躁免费麻豆 | 亚洲区小说区激情区图片区 | 又紧又大又爽精品一区二区 | 夜夜高潮次次欢爽av女 | 国产一区二区三区四区五区加勒比 | 人人爽人人澡人人高潮 | 精品一二三区久久aaa片 | 国产成人无码av在线影院 | 亚洲色无码一区二区三区 | 色综合久久久无码中文字幕 | 国产av人人夜夜澡人人爽麻豆 | 久久精品成人欧美大片 | av在线亚洲欧洲日产一区二区 | 免费视频欧美无人区码 | 少妇性荡欲午夜性开放视频剧场 | 午夜时刻免费入口 | 男女爱爱好爽视频免费看 | 欧美日韩视频无码一区二区三 | 中文毛片无遮挡高清免费 | 丰满人妻翻云覆雨呻吟视频 | 青青久在线视频免费观看 | 国产一精品一av一免费 | 国产精品a成v人在线播放 | 国产两女互慰高潮视频在线观看 | 中文字幕无码av波多野吉衣 | 大肉大捧一进一出视频出来呀 | 国产精品久久久午夜夜伦鲁鲁 | 无码av岛国片在线播放 | 久久成人a毛片免费观看网站 | 丰满肥臀大屁股熟妇激情视频 | 欧美 亚洲 国产 另类 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 亚洲国产精品一区二区第一页 | 97人妻精品一区二区三区 | 少妇无码一区二区二三区 | 一本大道久久东京热无码av | 黑人巨大精品欧美一区二区 | 亚洲天堂2017无码 | 国产亚洲精品久久久久久国模美 | 爽爽影院免费观看 | 亚洲男人av天堂午夜在 | 纯爱无遮挡h肉动漫在线播放 | 兔费看少妇性l交大片免费 | 国产亚洲精品久久久ai换 | 强开小婷嫩苞又嫩又紧视频 | 午夜精品一区二区三区在线观看 | 久久久久免费精品国产 | 波多野结衣乳巨码无在线观看 | 国产精品二区一区二区aⅴ污介绍 | 亚洲精品国产精品乱码视色 | 好爽又高潮了毛片免费下载 | 日本精品高清一区二区 | 台湾无码一区二区 | 成在人线av无码免费 | 中文字幕无码视频专区 | 成人免费无码大片a毛片 | 国产色精品久久人妻 | 欧美肥老太牲交大战 | 日韩欧美成人免费观看 | 中文精品无码中文字幕无码专区 | 日韩av激情在线观看 | 国产精品久久久久7777 | 无码午夜成人1000部免费视频 | 四虎国产精品一区二区 | 精品无码一区二区三区爱欲 | 精品人人妻人人澡人人爽人人 | 精品一二三区久久aaa片 | 亚洲国产精品久久人人爱 | 成人综合网亚洲伊人 | 正在播放老肥熟妇露脸 | 人妻插b视频一区二区三区 | 国产精华av午夜在线观看 | 一本大道久久东京热无码av | 鲁一鲁av2019在线 | 国产色视频一区二区三区 | 国产人妖乱国产精品人妖 | 日本大香伊一区二区三区 | av人摸人人人澡人人超碰下载 | 久久综合香蕉国产蜜臀av | 欧美人与牲动交xxxx | 国产激情艳情在线看视频 | 欧美成人高清在线播放 | 国产av剧情md精品麻豆 | 国产人成高清在线视频99最全资源 | 东京热无码av男人的天堂 | 四虎影视成人永久免费观看视频 | 国产婷婷色一区二区三区在线 | 理论片87福利理论电影 | 亚洲精品一区二区三区大桥未久 | 国产亚洲精品精品国产亚洲综合 | 亚洲色www成人永久网址 | 在线 国产 欧美 亚洲 天堂 | 日日天日日夜日日摸 | 久久久久se色偷偷亚洲精品av | 亚洲欧美精品aaaaaa片 | 亚洲日本一区二区三区在线 | 成人性做爰aaa片免费看 | 中文字幕无码日韩欧毛 | 人妻中文无码久热丝袜 | 人人妻人人澡人人爽欧美一区九九 | 国产又爽又黄又刺激的视频 | 在线а√天堂中文官网 | 5858s亚洲色大成网站www | 男人扒开女人内裤强吻桶进去 | 午夜无码人妻av大片色欲 | 亚洲成av人在线观看网址 | 国产无遮挡又黄又爽又色 | 色欲久久久天天天综合网精品 | 特黄特色大片免费播放器图片 | 国产精华av午夜在线观看 | 国产成人无码av在线影院 | 国产精品久久精品三级 | 网友自拍区视频精品 | 一个人免费观看的www视频 | 牛和人交xxxx欧美 | 国产精品久久福利网站 | 天天做天天爱天天爽综合网 | 天天av天天av天天透 | 男人扒开女人内裤强吻桶进去 | 香港三级日本三级妇三级 | 无码国产激情在线观看 | 国产亚洲日韩欧美另类第八页 | 欧美黑人巨大xxxxx | 欧美丰满熟妇xxxx性ppx人交 | 久久久久免费看成人影片 | 亚洲精品中文字幕乱码 | 日本精品少妇一区二区三区 | 欧洲熟妇色 欧美 | 人人妻人人澡人人爽精品欧美 | 国产成人人人97超碰超爽8 | 又大又紧又粉嫩18p少妇 | 国内精品久久毛片一区二区 | 少妇人妻偷人精品无码视频 | 老熟女乱子伦 | 亚洲男女内射在线播放 | 亚洲精品鲁一鲁一区二区三区 | 国产农村妇女高潮大叫 | 国产高清不卡无码视频 | 久久午夜无码鲁丝片午夜精品 | 自拍偷自拍亚洲精品被多人伦好爽 | 婷婷六月久久综合丁香 | 小sao货水好多真紧h无码视频 | 精品偷自拍另类在线观看 | 久久亚洲中文字幕精品一区 | 久久 国产 尿 小便 嘘嘘 | 国产成人人人97超碰超爽8 | 亚洲中文字幕成人无码 | 日韩成人一区二区三区在线观看 | 一本色道婷婷久久欧美 | 18禁止看的免费污网站 | 成人性做爰aaa片免费看不忠 | 中文字幕人妻无码一区二区三区 | 亚洲а∨天堂久久精品2021 | 中文无码成人免费视频在线观看 | 日日干夜夜干 | 亚洲无人区一区二区三区 | 999久久久国产精品消防器材 | 大屁股大乳丰满人妻 | 人人妻人人藻人人爽欧美一区 | 18禁黄网站男男禁片免费观看 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产精品99爱免费视频 | 亚洲日韩中文字幕在线播放 | 亚无码乱人伦一区二区 | 国产国语老龄妇女a片 | 日韩人妻少妇一区二区三区 | 国产精品人人爽人人做我的可爱 | 亚洲成a人片在线观看无码 | 超碰97人人做人人爱少妇 | 日韩av无码一区二区三区 | 久久无码人妻影院 | 在线精品国产一区二区三区 | 欧美人与禽猛交狂配 | 亚洲精品中文字幕乱码 | 精品久久久久久人妻无码中文字幕 | 亚洲爆乳精品无码一区二区三区 | 99久久精品日本一区二区免费 | 日本一本二本三区免费 | 天堂亚洲免费视频 | 欧美性猛交xxxx富婆 | 女人被爽到呻吟gif动态图视看 | 亚洲色www成人永久网址 | 精品国产一区二区三区四区在线看 | 亚洲中文字幕无码中字 | 亚洲综合无码久久精品综合 | 国产又爽又猛又粗的视频a片 | 精品国精品国产自在久国产87 | 67194成是人免费无码 | 亚洲国产av美女网站 | 精品国产乱码久久久久乱码 | 国产麻豆精品精东影业av网站 | 九月婷婷人人澡人人添人人爽 | 国产成人无码a区在线观看视频app | 又大又硬又黄的免费视频 | 国产精品毛片一区二区 | 婷婷丁香六月激情综合啪 | 美女极度色诱视频国产 | 国产午夜无码视频在线观看 | 麻花豆传媒剧国产免费mv在线 | 亚洲色欲色欲欲www在线 | 国产亚av手机在线观看 | 国产av一区二区精品久久凹凸 | 成人三级无码视频在线观看 | 日欧一片内射va在线影院 | 欧美放荡的少妇 | 动漫av网站免费观看 | 国产又粗又硬又大爽黄老大爷视 | 亚洲成熟女人毛毛耸耸多 | 久久五月精品中文字幕 | 国产热a欧美热a在线视频 | 伊人色综合久久天天小片 | 波多野结衣乳巨码无在线观看 | 奇米影视888欧美在线观看 | 亚洲综合久久一区二区 | 人妻少妇精品视频专区 | 亚洲国产精品一区二区美利坚 | 巨爆乳无码视频在线观看 | 免费观看又污又黄的网站 | 粗大的内捧猛烈进出视频 | 国产成人午夜福利在线播放 | 熟妇女人妻丰满少妇中文字幕 | 免费网站看v片在线18禁无码 | 蜜臀aⅴ国产精品久久久国产老师 | 久久精品女人的天堂av | 国产精品多人p群无码 | 真人与拘做受免费视频 | 伊人久久大香线蕉亚洲 | 伊在人天堂亚洲香蕉精品区 | 大肉大捧一进一出视频出来呀 | 荫蒂被男人添的好舒服爽免费视频 | 亚洲成a人片在线观看无码 | 日本精品人妻无码免费大全 | 国产精品无码成人午夜电影 | 国产精品久久久一区二区三区 | 久久这里只有精品视频9 | 成人一在线视频日韩国产 | 国产香蕉尹人视频在线 | 国产一区二区不卡老阿姨 | 久激情内射婷内射蜜桃人妖 | 亚洲熟妇色xxxxx欧美老妇 | 色综合久久久久综合一本到桃花网 | 国产成人无码av一区二区 | 任你躁国产自任一区二区三区 | 疯狂三人交性欧美 | 中文无码成人免费视频在线观看 | 欧美日韩视频无码一区二区三 | 国产成人无码av片在线观看不卡 | 未满小14洗澡无码视频网站 | 在线播放无码字幕亚洲 | 国产精品亚洲lv粉色 | 美女极度色诱视频国产 | 4hu四虎永久在线观看 | 桃花色综合影院 | 亚洲日韩乱码中文无码蜜桃臀网站 | 成熟女人特级毛片www免费 | 97人妻精品一区二区三区 | 性欧美疯狂xxxxbbbb | 无码一区二区三区在线 | 97夜夜澡人人爽人人喊中国片 | 亚洲日韩中文字幕在线播放 | 国产内射爽爽大片视频社区在线 | 欧美色就是色 | 麻豆md0077饥渴少妇 | www国产亚洲精品久久久日本 | 国产精品亚洲专区无码不卡 | 欧美激情内射喷水高潮 | 国产另类ts人妖一区二区 | 亚洲另类伦春色综合小说 | 人妻中文无码久热丝袜 | 99精品无人区乱码1区2区3区 | 欧美真人作爱免费视频 | 亚洲精品午夜国产va久久成人 | 久久精品人人做人人综合 | 欧美亚洲国产一区二区三区 | 亚洲国产日韩a在线播放 | 久久综合狠狠综合久久综合88 | 色婷婷香蕉在线一区二区 | 麻花豆传媒剧国产免费mv在线 | 88国产精品欧美一区二区三区 | 国产精品亚洲一区二区三区喷水 | 成人精品视频一区二区三区尤物 | 成人精品视频一区二区三区尤物 | 天天躁夜夜躁狠狠是什么心态 | 人妻与老人中文字幕 | 性欧美牲交xxxxx视频 | 永久免费观看国产裸体美女 | 狠狠cao日日穞夜夜穞av | 俄罗斯老熟妇色xxxx | 亚洲精品中文字幕乱码 | 久久精品人人做人人综合 | 国产精品办公室沙发 | 欧美日韩亚洲国产精品 | 免费国产黄网站在线观看 | 熟妇女人妻丰满少妇中文字幕 | 亚洲精品成人福利网站 | 午夜熟女插插xx免费视频 | 人人妻在人人 | 亚洲成av人片在线观看无码不卡 | 国产精品第一国产精品 | 欧美35页视频在线观看 | 97久久国产亚洲精品超碰热 | 人人妻人人澡人人爽欧美一区九九 | 国产精品va在线观看无码 | 中文字幕 人妻熟女 | 亚洲综合色区中文字幕 | 国产成人无码av在线影院 | 久久精品国产日本波多野结衣 | 亚洲码国产精品高潮在线 | 鲁大师影院在线观看 | 久久久精品国产sm最大网站 | 国产精品手机免费 | 久精品国产欧美亚洲色aⅴ大片 | 天堂一区人妻无码 | 久久99国产综合精品 | 国产69精品久久久久app下载 | 亚洲成a人片在线观看无码 | 亚洲精品综合五月久久小说 | 欧美成人高清在线播放 | 99久久久无码国产aaa精品 | 午夜福利电影 | 999久久久国产精品消防器材 | 中文字幕av无码一区二区三区电影 | 无码人妻丰满熟妇区五十路百度 | 亚洲乱码日产精品bd | 久久久久久久女国产乱让韩 | 国产精品久久福利网站 | 亚洲人成网站在线播放942 | 宝宝好涨水快流出来免费视频 | 亚洲国产日韩a在线播放 | 青草青草久热国产精品 | 亚洲乱亚洲乱妇50p | 亚洲欧美综合区丁香五月小说 | 大肉大捧一进一出好爽视频 | 亚洲成av人在线观看网址 | 强奷人妻日本中文字幕 | 国产亚洲人成在线播放 | 老熟女乱子伦 | 无遮挡国产高潮视频免费观看 | 欧美人与禽猛交狂配 | 桃花色综合影院 | 国产成人精品视频ⅴa片软件竹菊 | 国产精品内射视频免费 | 99久久久无码国产aaa精品 | 色欲久久久天天天综合网精品 | 国产成人无码av一区二区 | 欧美兽交xxxx×视频 | 欧美熟妇另类久久久久久不卡 | 漂亮人妻洗澡被公强 日日躁 | 强开小婷嫩苞又嫩又紧视频 | 在线 国产 欧美 亚洲 天堂 | 曰韩无码二三区中文字幕 | 亚洲码国产精品高潮在线 | 扒开双腿疯狂进出爽爽爽视频 | 中文字幕乱码人妻二区三区 | 欧美精品一区二区精品久久 | 成人av无码一区二区三区 | 男女性色大片免费网站 | 日日摸日日碰夜夜爽av | 性色av无码免费一区二区三区 | 极品尤物被啪到呻吟喷水 | 国产av剧情md精品麻豆 | 久久精品无码一区二区三区 | 国内精品人妻无码久久久影院 | 欧洲欧美人成视频在线 | 成人免费视频视频在线观看 免费 | 亚洲中文无码av永久不收费 | 乱码av麻豆丝袜熟女系列 | 久久99精品久久久久久动态图 | 丁香啪啪综合成人亚洲 | 亚洲理论电影在线观看 | 亚洲成a人片在线观看无码 | 久久精品国产99精品亚洲 | 日本乱人伦片中文三区 | 国产午夜亚洲精品不卡下载 | 亚洲大尺度无码无码专区 | 国产精品无码mv在线观看 | 在线亚洲高清揄拍自拍一品区 | 国产成人无码专区 | 岛国片人妻三上悠亚 | 亚洲成a人片在线观看日本 | 人人妻人人藻人人爽欧美一区 | 爽爽影院免费观看 | 九九久久精品国产免费看小说 | 亚洲第一无码av无码专区 | 日本饥渴人妻欲求不满 | 我要看www免费看插插视频 | 亚洲国产精品无码久久久久高潮 | 精品一区二区三区波多野结衣 | 亚洲成av人片在线观看无码不卡 | 成人三级无码视频在线观看 | 成人毛片一区二区 | 99久久精品午夜一区二区 | 亚洲午夜福利在线观看 | 欧美熟妇另类久久久久久不卡 | 在线视频网站www色 | 伊人久久大香线蕉午夜 | 成人精品天堂一区二区三区 | 国产成人无码区免费内射一片色欲 | 国产卡一卡二卡三 | 亲嘴扒胸摸屁股激烈网站 | 扒开双腿疯狂进出爽爽爽视频 | 性生交片免费无码看人 | 国产麻豆精品一区二区三区v视界 | 成人三级无码视频在线观看 | 国产婷婷色一区二区三区在线 | 成年美女黄网站色大免费全看 | 精品乱子伦一区二区三区 | 1000部啪啪未满十八勿入下载 | 免费网站看v片在线18禁无码 | 欧美自拍另类欧美综合图片区 | 在线精品亚洲一区二区 | 四虎国产精品免费久久 | 国内丰满熟女出轨videos | 亚洲熟妇自偷自拍另类 | 日韩 欧美 动漫 国产 制服 | 丰满人妻精品国产99aⅴ | 国产成人综合色在线观看网站 | 中文字幕人妻无码一区二区三区 | 久久精品国产一区二区三区肥胖 | 日韩欧美成人免费观看 | 日本欧美一区二区三区乱码 | 99视频精品全部免费免费观看 | 欧美日韩人成综合在线播放 | 亚洲国产欧美在线成人 | 国产精品久免费的黄网站 | 嫩b人妻精品一区二区三区 | 在线播放亚洲第一字幕 | 欧美freesex黑人又粗又大 | 无码av岛国片在线播放 | 东京无码熟妇人妻av在线网址 | 国产av无码专区亚洲awww | 国产疯狂伦交大片 | 亚洲欧美国产精品专区久久 | 国内精品人妻无码久久久影院蜜桃 | 国产极品美女高潮无套在线观看 | 丝袜人妻一区二区三区 | aa片在线观看视频在线播放 | 日本一区二区更新不卡 | 国产精品对白交换视频 | 丰满人妻一区二区三区免费视频 | 亚洲精品一区二区三区在线 | 国产激情精品一区二区三区 | √8天堂资源地址中文在线 | 色 综合 欧美 亚洲 国产 | 麻豆果冻传媒2021精品传媒一区下载 | 色妞www精品免费视频 | 国产偷自视频区视频 | 国产日产欧产精品精品app | 国产精品a成v人在线播放 | 亚洲精品中文字幕乱码 | 国产无遮挡又黄又爽又色 | 色爱情人网站 | 小sao货水好多真紧h无码视频 | 99er热精品视频 | 色综合天天综合狠狠爱 | 亚洲综合久久一区二区 | 1000部夫妻午夜免费 | 在线看片无码永久免费视频 | 国产美女精品一区二区三区 | 亚洲 另类 在线 欧美 制服 | av在线亚洲欧洲日产一区二区 | 国产精品无码成人午夜电影 | 亚洲日本一区二区三区在线 | 国产精品成人av在线观看 | 亚洲精品久久久久avwww潮水 | 国产精品人人妻人人爽 | 国产99久久精品一区二区 | 国产在热线精品视频 | 精品久久久无码中文字幕 | 人妻aⅴ无码一区二区三区 | 日本xxxx色视频在线观看免费 | 男女超爽视频免费播放 | 国产一区二区三区四区五区加勒比 | 在线观看国产一区二区三区 | 欧美成人高清在线播放 | 久久人妻内射无码一区三区 | 国产乱人偷精品人妻a片 | 色五月丁香五月综合五月 | 免费无码午夜福利片69 | 久久99热只有频精品8 | 日日鲁鲁鲁夜夜爽爽狠狠 | 中文字幕 亚洲精品 第1页 | 欧美日韩一区二区三区自拍 | 好男人社区资源 | 狠狠cao日日穞夜夜穞av | 久久久久久a亚洲欧洲av冫 | 女人被男人躁得好爽免费视频 | 理论片87福利理论电影 | 中文字幕无线码免费人妻 | 国产精品久久福利网站 | 丝袜 中出 制服 人妻 美腿 | 无码一区二区三区在线观看 | 亚洲午夜久久久影院 | 少妇无套内谢久久久久 | 丰满妇女强制高潮18xxxx | 无码人妻av免费一区二区三区 | 国产熟妇高潮叫床视频播放 | 人人妻人人澡人人爽欧美精品 | 在线 国产 欧美 亚洲 天堂 | 中文字幕+乱码+中文字幕一区 | 亚洲一区二区三区播放 | 狠狠噜狠狠狠狠丁香五月 | 久久综合给久久狠狠97色 | 成人动漫在线观看 | 亚洲国产午夜精品理论片 | 亚洲男人av香蕉爽爽爽爽 | 东京热无码av男人的天堂 | 99久久亚洲精品无码毛片 | 乱码午夜-极国产极内射 | 天天躁夜夜躁狠狠是什么心态 | 女人被男人爽到呻吟的视频 | 亚洲精品无码人妻无码 | 天堂一区人妻无码 | 丝袜 中出 制服 人妻 美腿 | 日韩av无码一区二区三区 | 国产亚洲精品久久久ai换 | 99国产欧美久久久精品 | 乱人伦人妻中文字幕无码久久网 | 免费看男女做好爽好硬视频 | 精品久久久无码中文字幕 | 双乳奶水饱满少妇呻吟 | 国产熟妇高潮叫床视频播放 | 蜜桃av抽搐高潮一区二区 | 国产又爽又猛又粗的视频a片 | 中文字幕人妻丝袜二区 | 好爽又高潮了毛片免费下载 | 日本在线高清不卡免费播放 | 国产农村妇女高潮大叫 | 亚洲狠狠色丁香婷婷综合 | 强开小婷嫩苞又嫩又紧视频 | 国产精品久久久久无码av色戒 | 国产精品国产自线拍免费软件 | 日韩亚洲欧美中文高清在线 | 亚洲精品午夜国产va久久成人 | 最近的中文字幕在线看视频 | 欧美日韩人成综合在线播放 | 久热国产vs视频在线观看 | 国产成人人人97超碰超爽8 | 国产精品多人p群无码 | 无码人妻精品一区二区三区不卡 | 国产婷婷色一区二区三区在线 | 国产精品资源一区二区 | 国产av剧情md精品麻豆 | 小泽玛莉亚一区二区视频在线 | 国产精品美女久久久久av爽李琼 | 午夜嘿嘿嘿影院 | 国产成人午夜福利在线播放 | 99久久精品国产一区二区蜜芽 | 亚洲区小说区激情区图片区 | 亚洲乱码日产精品bd | 亚洲高清偷拍一区二区三区 | 精品人妻人人做人人爽夜夜爽 | 欧美激情内射喷水高潮 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产精品久久国产三级国 | 国产午夜无码精品免费看 | 少妇被黑人到高潮喷出白浆 | 最新版天堂资源中文官网 | 国产香蕉尹人综合在线观看 | 色综合视频一区二区三区 | 蜜桃臀无码内射一区二区三区 | 亚洲精品综合五月久久小说 | 天堂久久天堂av色综合 | 国产成人无码a区在线观看视频app | 亚洲国产高清在线观看视频 | 亚洲熟妇色xxxxx欧美老妇y | 蜜臀aⅴ国产精品久久久国产老师 | 人人爽人人爽人人片av亚洲 | 中国大陆精品视频xxxx | 日本精品少妇一区二区三区 | 300部国产真实乱 | 国产成人精品优优av | 国产人妻人伦精品 | 免费看少妇作爱视频 | 亚洲色大成网站www国产 | 亚洲欧美精品aaaaaa片 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产av剧情md精品麻豆 | 男女猛烈xx00免费视频试看 | 国产激情一区二区三区 | 丰满人妻翻云覆雨呻吟视频 | 曰本女人与公拘交酡免费视频 | 日本熟妇乱子伦xxxx | 少妇无码一区二区二三区 | 99久久精品国产一区二区蜜芽 | 人人爽人人爽人人片av亚洲 | 欧美性黑人极品hd | 色 综合 欧美 亚洲 国产 | 国产色在线 | 国产 | 十八禁真人啪啪免费网站 | 国产成人无码一二三区视频 | 丰满肥臀大屁股熟妇激情视频 | 中文字幕人妻无码一夲道 | 少妇高潮喷潮久久久影院 | 欧美人与动性行为视频 | 久久久久久av无码免费看大片 |