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

如何編寫高性能的Lua代碼

開發 開發工具 后端
我認為最好的方式是在首次編寫的時候按照最佳實踐去寫出高性能的代碼,而不是編寫了一堆垃圾代碼后,再考慮優化。相信工作后大家都會對事后的優化的繁瑣都深有體會。一旦你決定編寫高性能的Lua代碼,下文將會指出在Lua中哪些代碼是可以優化的,哪些代碼會是運行緩慢的,然后怎么去優化它們。

前言

Lua是一門以其性能著稱的腳本語言,被廣泛應用在很多方面,尤其是游戲。像《魔獸世界》的插件,手機游戲《大掌門》《神曲》《迷失之地》等都是用Lua來寫的邏輯。

所以大部分時候我們不需要去考慮性能問題。Knuth有句名言:“過早優化是萬惡之源”。其意思就是過早優化是不必要的,會浪費大量時間,而且容易導致代碼混亂。

所以一個好的程序員在考慮優化性能前必須問自己兩個問題:“我的程序真的需要優化嗎?”。如果答案為是,那么再問自己:“優化哪個部分?”。

我們不能靠臆想和憑空猜測來決定優化哪個部分,代碼的運行效率必須是可測量的。我們需要借助于分析器來測定性能的瓶頸,然后著手優化。優化后,我們仍然要借助于分析器來測量所做的優化是否真的有效。

我認為***的方式是在***編寫的時候按照***實踐去寫出高性能的代碼,而不是編寫了一堆垃圾代碼后,再考慮優化。相信工作后大家都會對事后的優化的繁瑣都深有體會。

一旦你決定編寫高性能的Lua代碼,下文將會指出在Lua中哪些代碼是可以優化的,哪些代碼會是運行緩慢的,然后怎么去優化它們。

使用local

在代碼運行前,Lua會把源碼預編譯成一種中間碼,類似于Java的虛擬機。這種格式然后會通過C的解釋器進行解釋,整個過程其實就是通過一個while循環,里面有很多的switch...case語句,一個case對應一條指令來解析。

自Lua 5.0之后,Lua采用了一種類似于寄存器的虛擬機模式。Lua用棧來儲存其寄存器。每一個活動的函數,Lua都會其分配一個棧,這個棧用來儲存函數里的活動記錄。每一個函數的棧都可以儲存至多250個寄存器,因為棧的長度是用8個比特表示的。

有了這么多的寄存器,Lua的預編譯器能把所有的local變量儲存在其中。這就使得Lua在獲取local變量時其效率十分的高。

舉個栗子: 假設a和b為local變量,a = a + b的預編譯會產生一條指令:
 

  1. ;a是寄存器0 b是寄存器1  
  2. ADD 0 0 1 

但是若a和b都沒有聲明為local變量,則預編譯會產生如下指令:

  1. GETGLOBAL    0 0    ;get a  
  2. GETGLOBAL    1 1    ;get b  
  3. ADD          0 0 1  ;do add  
  4. SETGLOBAL    0 0    ;set a  

所以你懂的:在寫Lua代碼時,你應該盡量使用local變量。

以下是幾個對比測試,你可以復制代碼到你的編輯器中,進行測試。

  1. a = os.clock()  
  2. for i = 1,10000000 do 
  3.   local x = math.sin(i)  
  4. end  
  5. b = os.clock()  
  6. print(b-a) -- 1.113454 

math.sin賦給local變量sin

  1. a = os.clock()  
  2. local sin = math.sin  
  3. for i = 1,10000000 do 
  4.   local x = sin(i)  
  5. end  
  6. b = os.clock()  
  7. print(b-a) --0.75951 

直接使用math.sin,耗時1.11秒;使用local變量sin來保存math.sin,耗時0.76秒。可以獲得30%的效率提升!

關于表(table)

表在Lua中使用十分頻繁,因為表幾乎代替了Lua的所有容器。所以快速了解一下Lua底層是如何實現表,對我們編寫Lua代碼是有好處的。

Lua的表分為兩個部分:數組(array)部分和哈希(hash)部分。數組部分包含所有從1到n的整數鍵,其他的所有鍵都儲存在哈希部分中。

哈希部分其實就是一個哈希表,哈希表本質是一個數組,它利用哈希算法將鍵轉化為數組下標,若下標有沖突(即同一個下標對應了兩個不同的鍵),則它會將沖突的下標上創建一個鏈表,將不同的鍵串在這個鏈表上,這種解決沖突的方法叫做:鏈地址法。

當我們把一個新鍵值賦給表時,若數組和哈希表已經滿了,則會觸發一個再哈希(rehash)。再哈希的代價是高昂的。首先會在內存中分配一個新的長度的數組,然后將所有記錄再全部哈希一遍,將原來的記錄轉移到新數組中。新哈希表的長度是最接近于所有元素數目的2的乘方。

當創建一個空表時,數組和哈希部分的長度都將初始化為0,即不會為它們初始化任何數組。讓我們來看下執行下面這段代碼時在Lua中發生了什么:

  1. local a = {}  
  2. for i=1,3 do 
  3.     a[i] = true 
  4. end 

最開始,Lua創建了一個空表a,在***次迭代中,a[1] = true觸發了一次rehash,Lua將數組部分的長度設置為2^0,即1,哈希部分仍為空。在第二次迭代中,a[2] = true再次觸發了rehash,將數組部分長度設為2^1,即2。***一次迭代,又觸發了一次rehash,將數組部分長度設為2^2,即4。

下面這段代碼:

  1. a = {}  
  2. a.x = 1; a.y = 2; a.z = 3 

與上一段代碼類似,只是其觸發了三次表中哈希部分的rehash而已。

只有三個元素的表,會執行三次rehash;然而有一百萬個元素的表僅僅只會執行20次rehash而已,因為2^20 = 1048576 > 1000000。但是,如果你創建了非常多的長度很小的表(比如坐標點:point = {x=0,y=0}),這可能會造成巨大的影響。

如果你有很多非常多的很小的表需要創建時,你可以將其預先填充以避免rehash。比如:{true,true,true},Lua知道這個表有三個元素,所以Lua直接創建了三個元素長度的數組。類似的,{x=1, y=2, z=3},Lua會在其哈希部分中創建長度為4的數組。

以下代碼執行時間為1.53秒:

  1. a = os.clock()  
  2. for i = 1,2000000 do 
  3.     local a = {}  
  4.     a[1] = 1; a[2] = 2; a[3] = 3  
  5. end  
  6. b = os.clock()  
  7. print(b-a)  --1.528293 

如果我們在創建表的時候就填充好它的大小,則只需要0.75秒,一倍的效率提升!

  1. a = os.clock()  
  2. for i = 1,2000000 do 
  3.     local a = {1,1,1}  
  4.     a[1] = 1; a[2] = 2; a[3] = 3  
  5. end  
  6. b = os.clock()  
  7. print(b-a)  --0.746453 

所以,當需要創建非常多的小size的表時,應預先填充好表的大小。

關于字符串

與其他主流腳本語言不同的是,Lua在實現字符串類型有兩方面不同。

***,所有的字符串在Lua中都只儲存一份拷貝。當新字符串出現時,Lua檢查是否有其相同的拷貝,若沒有則創建它,否則,指向這個拷貝。這可以使得字符串比較和表索引變得相當的快,因為比較字符串只需要檢查引用是否一致即可;但是這也降低了創建字符串時的效率,因為Lua需要去查找比較一遍。

第二,所有的字符串變量,只保存字符串引用,而不保存它的buffer。這使得字符串的賦值變得十分高效。例如在Perl中,$x = $y,會將$y的buffer整個的復制到$x的buffer中,當字符串很長時,這個操作的代價將十分昂貴。而在Lua,同樣的賦值,只復制引用,十分的高效。

但是只保存引用會降低在字符串連接時的速度。在Perl中,$s = $s . 'x'和$s .= 'x'的效率差距驚人。前者,將會獲取整個$s的拷貝,并將’x’添加到它的末尾;而后者,將直接將’x’插入到$x的buffer末尾。

由于后者不需要進行拷貝,所以其效率和$s的長度無關,因為十分高效。

在Lua中,并不支持第二種更快的操作。以下代碼將花費6.65秒:

  1. a = os.clock()  
  2. local s = '' 
  3. for i = 1,300000 do 
  4.     s = s .. 'a' 
  5. end  
  6. b = os.clock()  
  7. print(b-a)  --6.649481 

我們可以用table來模擬buffer,下面的代碼只需花費0.72秒,9倍多的效率提升:

  1. a = os.clock()  
  2. local s = '' 
  3. local t = {}  
  4. for i = 1,300000 do 
  5.     t[#t + 1] = 'a' 
  6. end  
  7. s = table.concat( t, '')  
  8. b = os.clock()  
  9. print(b-a)  --0.07178 

所以:在大字符串連接中,我們應避免..。應用table來模擬buffer,然后concat得到最終字符串

#p#

3R原則

3R原則(the rules of 3R)是:減量化(reducing),再利用(reusing)和再循環(recycling)三種原則的簡稱。

3R原則本是循環經濟和環保的原則,但是其同樣適用于Lua。

Reducing

有許多辦法能夠避免創建新對象和節約內存。例如:如果你的程序中使用了太多的表,你可以考慮換一種數據結構來表示。

舉個栗子。 假設你的程序中有多邊形這個類型,你用一個表來儲存多邊形的頂點:

  1. polyline = {  
  2.     { x = 1.1, y = 2.9 },  
  3.     { x = 1.1, y = 3.7 },  
  4.     { x = 4.6, y = 5.2 },  
  5.     ...  

以上的數據結構十分自然,便于理解。但是每一個頂點都需要一個哈希部分來儲存。如果放置在數組部分中,則會減少內存的占用:

  1. polyline = {  
  2.     { 1.1, 2.9 },  
  3.     { 1.1, 3.7 },  
  4.     { 4.6, 5.2 },  
  5.     ...  

一百萬個頂點時,內存將會由153.3MB減少到107.6MB,但是代價是代碼的可讀性降低了。

最變態的方法是:

  1. polyline = {  
  2.     x = {1.1, 1.1, 4.6, ...},  
  3.     y = {2.9, 3.7, 5.2, ...}  

一百萬個頂點,內存將只占用32MB,相當于原來的1/5。你需要在性能和代碼可讀性之間做出取舍。

在循環中,我們更需要注意實例的創建。

  1. for i=1,n do  
  2.     local t = {1,2,3,'hi'}  
  3.     --執行邏輯,但t不更改  
  4.     ...  
  5. end 

我們應該把在循環中不變的東西放到循環外來創建:

  1. local t = {1,2,3,'hi'}  
  2. for i=1,n do  
  3.     --執行邏輯,但t不更改  
  4.     ...  
  5. end 

Reusing

如果無法避免創建新對象,我們需要考慮重用舊對象。

考慮下面這段代碼:

  1. local t = {}  
  2. for i = 1970, 2000 do  
  3.     t[i] = os.time({year = imonth = 6day = 14})  
  4. end 

在每次循環迭代中,都會創建一個新表{year = i, month = 6, day = 14},但是只有year是變量。

下面這段代碼重用了表:

  1. local t = {}  
  2. local aux = {year = nilmonth = 6day = 14}  
  3. for i = 1970, 2000 do  
  4.     aux.year = i;  
  5.     t[i] = os.time(aux)  
  6. end 

另一種方式的重用,則是在于緩存之前計算的內容,以避免后續的重復計算。后續遇到相同的情況時,則可以直接查表取出。這種方式實際就是動態規劃效率高的原因所在,其本質是用空間換時間。

Recycling

Lua自帶垃圾回收器,所以我們一般不需要考慮垃圾回收的問題。

了解Lua的垃圾回收能使得我們編程的自由度更大。

Lua的垃圾回收器是一個增量運行的機制。即回收分成許多小步驟(增量的)來進行。

頻繁的垃圾回收可能會降低程序的運行效率。

我們可以通過Lua的collectgarbage函數來控制垃圾回收器。

collectgarbage函數提供了多項功能:停止垃圾回收,重啟垃圾回收,強制執行一次回收循環,強制執行一步垃圾回收,獲取Lua占用的內存,以及兩個影響垃圾回收頻率和步幅的參數。

對于批處理的Lua程序來說,停止垃圾回收collectgarbage("stop")會提高效率,因為批處理程序在結束時,內存將全部被釋放。

對于垃圾回收器的步幅來說,實際上很難一概而論。更快幅度的垃圾回收會消耗更多CPU,但會釋放更多內存,從而也降低了CPU的分頁時間。只有小心的試驗,我們才知道哪種方式更適合。

結語

我們應該在寫代碼時,按照高標準去寫,盡量避免在事后進行優化。

如果真的有性能問題,我們需要用工具量化效率,找到瓶頸,然后針對其優化。當然優化過后需要再次測量,查看是否優化成功。

在優化中,我們會面臨很多選擇:代碼可讀性和運行效率,CPU換內存,內存換CPU等等。需要根據實際情況進行不斷試驗,來找到最終的平衡點。

***,有兩個***武器:

***、使用LuaJIT,LuaJIT可以使你在不修改代碼的情況下獲得平均約5倍的加速。查看LuaJIT在x86/x64下的性能提升比

第二、將瓶頸部分用C/C++來寫。因為Lua和C的天生近親關系,使得Lua和C可以混合編程。但是C和Lua之間的通訊會抵消掉一部分C帶來的優勢。

注意:這兩者并不是兼容的,你用C改寫的Lua代碼越多,LuaJIT所帶來的優化幅度就越小。

聲明

這篇文章是基于Lua語言的創造者Roberto Ierusalimschy在Lua Programming Gems 中的Lua Performance Tips翻譯改寫而來。本文沒有直譯,做了許多刪節,可以視為一份筆記。

感謝Roberto在Lua上的辛勤勞動和付出!

原文鏈接:http://wuzhiwei.net/lua_performance/

責任編輯:林師授 來源: 吳智煒的博客
相關推薦

2024-03-20 08:00:00

軟件開發Java編程語言

2015-12-17 13:19:29

編寫高性能Swift

2012-12-17 13:51:22

Web前端JavaScriptJS

2009-06-24 15:00:39

Javascript代

2018-01-12 14:37:34

Java代碼實踐

2022-02-24 09:00:38

React代碼模式

2014-11-25 10:03:42

JavaScript

2022-03-22 14:06:43

Java性能技術匯編

2011-04-07 09:18:59

MySQL語法

2024-04-17 08:35:04

Lua腳本Redis數據結構

2025-09-09 09:32:04

2011-03-11 09:51:47

Java NIO

2016-08-23 14:37:21

2017-12-05 08:41:14

高性能存儲產品

2012-09-11 11:08:23

Github系統

2019-08-26 18:20:05

JavascriptWeb前端

2016-11-28 09:19:27

2012-07-11 10:51:37

編程

2011-04-07 09:25:25

內存Java

2011-04-25 14:06:23

java
點贊
收藏

51CTO技術棧公眾號

情事1991在线| 色狠狠av一区二区三区| 91九色在线观看| 久久亚洲成人av| 婷婷综合一区| 欧美少妇bbb| 97超碰在线视| 国产一区二区三区福利| 美女视频黄久久| 久久99久久亚洲国产| 国产黄色网址在线观看| a一区二区三区亚洲| 亚洲精品欧美二区三区中文字幕| 91黄色国产视频| 黄色在线视频网址| 一区二区三区四区在线观看国产日韩 | 在线观看亚洲精品| 国产成人免费高清视频| 色综合888| 国产精品一区二区三区乱码| 国产va免费精品高清在线观看| 午夜爽爽爽男女免费观看| 日韩av三区| 91精品国产综合久久福利软件| 动漫av网站免费观看| 精品国产99久久久久久| 久久久精品2019中文字幕之3| 亚洲www在线观看| 亚洲图片欧美日韩| 亚洲国产精品一区制服丝袜| xvideos亚洲人网站| 国产又爽又黄无码无遮挡在线观看| 亚洲aⅴ网站| 在线观看欧美精品| 欧美日韩二三区| 久久久久黄久久免费漫画| 亚洲国产精品精华液ab| 欧美连裤袜在线视频| 亚洲av色香蕉一区二区三区| 麻豆视频观看网址久久| 日韩美女av在线免费观看| 激情综合网五月天| 亚洲国产成人精品女人| 欧美在线二区| 国产电影精品久久禁18| 国产精品色婷婷视频| 天堂中文在线网| 妖精视频成人观看www| 欧美大片在线看免费观看| 亚洲女人久久久| 久久国产亚洲精品| 深夜福利日韩在线看| 在线观看免费小视频| 九九视频免费观看视频精品| 日韩av网站在线| 黄页网站在线看| www.欧美| 日韩一区二区视频在线观看| www.色就是色.com| 四虎国产精品永久在线国在线 | av一区二区三区四区| av成人观看| 亚洲第一页视频| 国产传媒久久文化传媒| av电影成人| 日本精品一二区| 97久久精品人人做人人爽50路| 国产一区二区精品免费| 天堂成人在线观看| 久久久久久久综合色一本| 欧美中文娱乐网| av免费在线一区二区三区| 日本一区二区三区在线观看| 色狠狠久久av五月综合|| 人人干在线视频| 亚洲欧美日韩国产成人精品影院| 欧美日韩中文字幕在线播放| 欧美xxxx免费虐| 精品福利免费观看| 五月天婷婷激情视频| 免费一区二区三区四区| 91麻豆精品国产91久久久更新时间| 亚洲欧美一区二区三区不卡| 97一区二区国产好的精华液| 亚洲精品suv精品一区二区| 人人妻人人澡人人爽人人精品| 国产一卡不卡| 久久综合久中文字幕青草| 久久精品这里只有精品| 国产精品久久久久久模特| 国产精品成人观看视频国产奇米| 在线免费观看中文字幕| 国产又粗又猛又爽又黄91精品| 成人午夜电影免费在线观看| 男男激情在线| 亚洲激情一二三区| 超碰网在线观看| 国产精品一区二区美女视频免费看| 精品国一区二区三区| 亚洲午夜福利在线观看| 97久久视频| 97精品在线观看| 中文字幕在线播放不卡| 福利一区福利二区| 视频二区一区| 91老司机福利在线| 欧美日本在线看| 捆绑裸体绳奴bdsm亚洲| 91日韩在线| 777精品视频| 国产伦精品一区二区三区视频痴汉 | 中文字幕一区二区三区在线观看| 成人在线视频一区二区三区| 成人在线爆射| 亚洲精品一区二区三区影院| 日韩精品久久久久久久的张开腿让| 激情欧美一区| 成人黄色激情网| 日本国产在线| 亚洲综合久久av| 黄色片视频在线| 亚州av一区| 欧美成人亚洲成人| 成人黄色三级视频| 95精品视频在线| 成人高清dvd| 日韩色性视频| 亚洲性av在线| 丰满少妇xoxoxo视频| 成人自拍视频在线观看| 一区二区日本伦理| 欧美一级二级视频| 日韩精品免费一线在线观看| 久久久香蕉视频| 国产最新精品免费| 一区二区日本伦理| 免费成人毛片| 日韩中文字幕精品视频| 亚洲av无码乱码国产精品fc2| aaa亚洲精品| 中国丰满熟妇xxxx性| 试看120秒一区二区三区| 色偷偷av亚洲男人的天堂| 国产99久久久久久免费看| 久久婷婷久久一区二区三区| 国产精品无码人妻一区二区在线| 精品久久亚洲| 欧美成人第一页| 97人妻精品一区二区三区| 国产农村妇女毛片精品久久麻豆 | 日本不卡免费在线视频| 美国av一区二区三区| 亚洲福利影院| 亚洲欧美另类在线观看| 国产午夜精品久久久久| 久久精品人人做人人爽人人| 国产av无码专区亚洲精品| 九九热爱视频精品视频| 国产精品v片在线观看不卡| 免费人成黄页在线观看忧物| 色噜噜偷拍精品综合在线| 精品无码人妻一区| 日韩国产欧美三级| 亚洲精品欧美精品| 9999在线精品视频| 欧美美最猛性xxxxxx| 丰满少妇一级片| 亚洲国产一区二区在线播放| 国产chinese中国hdxxxx| aⅴ色国产欧美| 欧美美乳视频网站在线观看| 欧美日韩激情电影| 日韩在线视频导航| 国产99视频在线| 亚洲国产精品一区二区久久恐怖片| 不许穿内裤随时挨c调教h苏绵| 在线看片欧美| 日本一区二区三区四区在线观看 | 免费看黄色av| 蜜臀av性久久久久蜜臀aⅴ| 中文字幕在线亚洲精品| h视频久久久| 国产xxx69麻豆国语对白| 色影院视频在线| 精品sm捆绑视频| 日日夜夜狠狠操| 亚洲婷婷在线视频| 在线免费看黄色片| 日韩电影在线免费| 国产精品啪啪啪视频| 啪啪激情综合网| 国产一区红桃视频| 白白色在线观看| 亚洲一区999| 亚洲h视频在线观看| 欧美日韩在线免费| 精品国产国产综合精品| 成人av免费在线播放| 99视频在线视频| 狠狠入ady亚洲精品经典电影| 欧美在线播放一区| 亚洲一区 二区| 国产精品高潮呻吟久久av黑人| av网站大全在线| 亚洲欧美日韩天堂| 精品人妻无码一区二区色欲产成人| 福利微拍一区二区| 国产黄色的视频| 久久久精品免费观看| 最好看的中文字幕| 日韩经典中文字幕一区| 日b视频免费观看| 波多野结衣在线观看一区二区三区| 粉嫩av四季av绯色av第一区| 日韩欧美一区二区三区在线观看 | 欧美亚洲免费高清在线观看 | 一色桃子av在线| 一本色道久久88精品综合| 成人午夜免费福利| 欧美精品自拍偷拍| 精品人妻一区二区三区潮喷在线| 一区二区视频免费在线观看| 久久久国产一级片| 99久久免费视频.com| 在线成人免费av| 奇米色一区二区| 日韩视频在线免费看| 黄色日韩在线| 超碰在线免费观看97| 欧美丝袜丝交足nylons172| 国产一区二区免费在线观看| 国产视频网站一区二区三区| 国产精品人成电影| 美女一区网站| 欧美在线观看网站| 99riav视频在线观看| 欧美猛交免费看| bestiality新另类大全| 色婷婷综合久久久久| 一区二区三区视频网站 | 91亚洲一区精品| 欧美日韩免费电影| 国产精品久久久久久久久影视| 自拍一区在线观看| 91国产中文字幕| av在线视屏| 久久久久久一区二区三区| 欧美videossex另类| 欧美巨猛xxxx猛交黑人97人| 二区三区四区高清视频在线观看| 色老头一区二区三区| av成人手机在线| 在线看日韩av| 99青草视频在线播放视| 中文字幕日韩有码| h视频在线免费| 中文字幕亚洲无线码a| 伊人免费在线| 另类色图亚洲色图| 91精品久久| 欧美国产欧美亚洲国产日韩mv天天看完整| 9191在线播放| 久久欧美在线电影| 手机在线理论片| 国产成人a亚洲精品| 日韩一级二级| 国产在线视频不卡| 天堂av一区| 国产精品视频500部| 奇米影视777在线欧美电影观看| 欧美日本韩国国产| 色喇叭免费久久综合网| 亚洲第一页在线视频| 欧美 日韩 国产精品免费观看| 香港三级日本三级a视频| 91久久午夜| 91看片就是不一样| 久久99精品国产| 不许穿内裤随时挨c调教h苏绵 | 丁香激情五月少妇| 国产精品久久久久久一区二区三区| 夫妻性生活毛片| 亚洲精品欧美综合四区| 青青国产在线观看| 欧美亚洲日本国产| 国产情侣一区二区| 日韩国产精品一区| 瑟瑟视频在线| 91国语精品自产拍在线观看性色| 三上悠亚亚洲一区| 91免费视频国产| 日本一道高清一区二区三区| 婷婷四房综合激情五月| 国产一在线精品一区在线观看| 日韩精品―中文字幕| 麻豆精品久久精品色综合| 人妻精油按摩bd高清中文字幕| 91浏览器在线视频| 成人自拍小视频| 欧美日韩国产丝袜另类| 一区二区久久精品66国产精品| 亚洲精品一区二区三区福利| 国产精品久久久久一区二区国产| 欧美日韩国产第一页| 成人开心激情| 国产高清一区二区三区| 日韩免费久久| 无码aⅴ精品一区二区三区浪潮 | 欧美日韩免费看| 国产精品伦理一区| 国产午夜精品理论片a级探花| 成人免费网址| 国产精品第100页| 国产三级精品三级在线观看国产| 一级日韩一区在线观看| 国产视频一区三区| 国偷自产av一区二区三区麻豆| 欧美激情在线免费观看| 好吊操这里只有精品| 欧美一区二区在线看| 国产在线观看网站| 午夜免费久久久久| 欧美视频二区欧美影视| 五月天综合网| 久久动漫亚洲| 精品国产一区在线| 一区二区免费视频| 91影院在线播放| 在线观看久久av| av综合电影网站| 精品欧美一区二区久久久伦| 欧美黄色一级视频| 中文字幕在线视频一区二区三区| 久久久www成人免费毛片麻豆| 色播视频在线播放| 亚洲福利小视频| 欧洲一区二区三区| 91中文在线观看| 91精品国产91久久久久久密臀| 亚洲综合色在线观看| 久久久久国产一区二区三区四区 | 99热在线精品观看| 波多野结衣中文字幕在线播放| 日韩一区在线免费观看| 中文永久免费观看| 国产亚洲视频中文字幕视频| 国产自产自拍视频在线观看| 国产精品日韩高清| 亚洲日韩视频| 中文字幕人妻一区二区三区| 亚洲在线视频免费观看| 性做久久久久久久久久| 欧美黑人巨大xxx极品| 成人av动漫| 欧美一级欧美一级| 99麻豆久久久国产精品免费 | 91亚洲精品一区二区| 欧美成人一品| 国产白袜脚足j棉袜在线观看 | 一级黄色在线视频| 亚洲欧美制服第一页| 成人开心激情| 中文字幕中文字幕在线中一区高清| 麻豆成人av在线| 国产视频精品免费| 日韩欧美国产一二三区| 91禁在线看| 久久综合入口| 蜜臀久久久久久久| 中国一级片在线观看| 精品少妇一区二区三区在线视频| 97蜜桃久久| 日产精品高清视频免费| 久久99久久99精品免视看婷婷| 日本一级二级视频| 亚洲成人久久久| 天天综合网站| 中文字幕欧美日韩一区二区三区| 国产伦理精品不卡| 欧美精品二区三区| www国产亚洲精品久久网站| 91蝌蚪精品视频| 91黄色小网站| 国产精品三级在线观看| 超碰免费在线97| 日本精品久久久久久久| 久久精品av| 亚洲精品乱码久久久久久蜜桃欧美| 狠狠色香婷婷久久亚洲精品| 成人在线观看网站| www.久久艹| 日韩有码一区二区三区| 亚洲色婷婷一区二区三区| 日韩av网站在线| 日本久久一区| 成熟了的熟妇毛茸茸| 中文字幕在线观看一区| 色呦呦中文字幕| 国产日韩在线看| 国产精品久久久免费|