成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > 編寫高性能Lua代碼的方法

編寫高性能Lua代碼的方法

熱門標簽:開通400電話申請流程 電腦外呼系統(tǒng)輻射大嗎 400手機電話免費辦理 智能語音電銷的機器人 武漢百應人工智能電銷機器人 如何利用高德地圖標注家 揚州電銷外呼系統(tǒng)軟件 上海企業(yè)外呼系統(tǒng)排名 百度地圖標注位置網站

前言

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

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

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

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

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

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

使用local

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

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

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

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

復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

GETGLOBAL    0 0    ;get a
GETGLOBAL    1 1    ;get b
ADD          0 0 1  ;do add
SETGLOBAL    0 0    ;set a

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

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

復制代碼 代碼如下:

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

把math.sin賦給local變量sin:

復制代碼 代碼如下:

a = os.clock()
local sin = math.sin
for i = 1,10000000 do
  local x = sin(i)
end
b = os.clock()
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的整數鍵,其他的所有鍵都儲存在哈希部分中。

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

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

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

復制代碼 代碼如下:

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

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

下面這段代碼:

復制代碼 代碼如下:

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

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

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

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

以下代碼執(zhí)行時間為1.53秒:

復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

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

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

關于字符串

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

第一,所有的字符串在Lua中都只儲存一份拷貝。當新字符串出現時,Lua檢查是否有其相同的拷貝,若沒有則創(chuàng)建它,否則,指向這個拷貝。這可以使得字符串比較和表索引變得相當的快,因為比較字符串只需要檢查引用是否一致即可;但是這也降低了創(chuàng)建字符串時的效率,因為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秒:

復制代碼 代碼如下:

a = os.clock()
local s = ''
for i = 1,300000 do
    s = s .. 'a'
end
b = os.clock()
print(b-a)  --6.649481

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

復制代碼 代碼如下:

a = os.clock()
local s = ''
local t = {}
for i = 1,300000 do
    t[#t + 1] = 'a'
end
s = table.concat( t, '')
b = os.clock()
print(b-a)  --0.07178

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

3R原則

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

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

Reducing

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

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

復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

polyline = {
    { 1.1, 2.9 },
    { 1.1, 3.7 },
    { 4.6, 5.2 },
    ...
}

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

最變態(tài)的方法是:

復制代碼 代碼如下:

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

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

在循環(huán)中,我們更需要注意實例的創(chuàng)建。

復制代碼 代碼如下:

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

我們應該把在循環(huán)中不變的東西放到循環(huán)外來創(chuàng)建:

復制代碼 代碼如下:

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

Reusing

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

考慮下面這段代碼:

復制代碼 代碼如下:

local t = {}
for i = 1970, 2000 do
    t[i] = os.time({year = i, month = 6, day = 14})
end

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

下面這段代碼重用了表:

復制代碼 代碼如下:

local t = {}
local aux = {year = nil, month = 6, day = 14}
for i = 1970, 2000 do
    aux.year = i;
    t[i] = os.time(aux)
end

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

Recycling

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

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

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

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

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

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

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

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

結語

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

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

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

最后,有兩個終極武器:

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

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

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

聲明

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

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

標簽:延邊 宜賓 嘉峪關 黑龍江 新余 武漢 張掖 江西

巨人網絡通訊聲明:本文標題《編寫高性能Lua代碼的方法》,本文關鍵詞  編寫,高性能,Lua,代碼,的,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《編寫高性能Lua代碼的方法》相關的同類信息!
  • 本頁收集關于編寫高性能Lua代碼的方法的相關信息資訊供網民參考!
  • 推薦文章
    成人精品电影| 国产乱淫a∨片免费视频| 日本一本草久在线中文| 国产亚洲激情在线| 久久久久国产成人精品亚洲午夜| 黄色大片中文字幕| 精品国产无码一区二区三区| 国产小视频免费在线网址| 99鲁鲁精品一区二区三区| 日韩欧美电影一二三| 一区二区三区中文字幕电影| 亚洲偷欧美偷国内偷| 欧美日韩中文字幕一区二区| 日本韩国免费观看| 一区二区免费电影| 99精品视频在线免费播放| 天天操天天擦| 亚洲免费久久| 久草在线资源福利站| 久久嫩草精品久久久精品| 激情视频小说图片| 国产精品一区在线观看| 天天爽夜夜爽夜夜爽精品| 亚洲av成人无码久久精品老人| 久久亚洲影视| 成人在线app| 免费在线观看的av网站| 亚洲精品一线| 亚洲欧美一区二区三区不卡| 久久免费精品一区二区| 久久久久久久久久久久久9999| 久久久久99精品| 天天操夜夜操视频| 精品在线91| 国产亚洲欧美一区在线观看| 国产69精品久久久久9999apgf| 3d动漫一区二区三区在线观看| 亚洲一区免费在线观看| 天天干天天舔天天操| 亚洲v国产v在线观看| 91免费国产视频| 国产精品日韩久久久| 日韩久久久久久久| 91视频福利| 激情五月六月婷婷| 精品国产第一国产综合精品| 高清成人在线| 欧美a视频在线| 99精品国产热久久91蜜凸| 欧美一级片在线视频| 国产精品国色综合久久| 在线看日韩欧美| 亚洲欧美制服中文字幕| 色婷婷精品久久二区二区蜜臀av| 精品国产亚洲一区二区三区在线| 国产精品乱码人人做人人爱| 欧美欧美欧美| 亚洲综合小说| 天天影视色香欲综合网天天录日日录| 成人久久精品人妻一区二区三区| 国产欧美日韩亚州综合| 亚洲国产精品久久久久秋霞影院| 日韩福利在线视频| 日本福利视频在线观看| 香蕉97视频观看在线观看| 妖精视频在线观看免费| 黄色高清视频在线观看| 久久综合九色九九| 欧美1级日本1级| 在线观看免费黄网站| 50一60岁老妇女毛片| 无码日本精品xxxxxxxxx| 亚洲播播91| 极品粉嫩国产18尤物| 午夜男人视频在线观看| 国产精品毛片一区二区| 51精品国产黑色丝袜高跟鞋| 秋霞成人影院| 久久午夜激情| 一本色道久久综合亚洲精品高清| 美女视频网站在线观看| 污污的网站免费| 成年人小视频在线观看| 在线免费观看黄色小视频| 亚洲一区二区三区精品中文字幕| 亚洲人高潮女人毛茸茸| 成人免费观看49www在线观看| 欧美一区二区免费在线观看| 成人av网站大全| 精品人伦一区二区三区蜜桃免费| 全网免费在线播放视频入口| 日韩av电影中文字幕| 人妻偷人精品一区二区三区| 国产传媒免费观看| 久久成人免费日本黄色| xvideos国产在线视频| 天堂av资源网| 日韩在线视频国产| www 四虎| 91社区在线观看播放| 亚洲美女在线播放| 免费高清视频精品| 欧美精品video| 亚洲精品国产91| 九色91蝌蚪在线| 国产精品av一区二区| 青草综合视频| xxx电影网| 欧美一区二区三区在线电影| 国产精品欧美激情在线播放| 一区二区不卡久久精品| 在线免费观看视频黄| 日本少妇bbwbbw精品| 亚洲欧美日韩国产一区| 日韩av在线看免费观看| 亚洲成人av资源网| 色午夜这里只有精品| 欧美色欧美亚洲另类二区精品| 成人精品一区二区不卡视频| 国产免费av国片精品草莓男男| 国产一区二区在线| 婷婷久久综合九色综合99蜜桃| 欧美禁忌电影网| 亚洲男人都懂第一日本| 亚洲一区欧美激情| 久久网站热最新地址| 成人免费看视频网站| 丝袜人妻一区二区三区| 第九色区av在线| 免费国产自线拍一欧美视频| 欧美国产精品专区| 国产一区二区三区四区五区3d| 欧美77777| 91电影在线| 欧美久久久久久久久久久久| 国产99久久久国产精品| 岛国av在线免费| 亚洲18私人小影院| 亚洲黄色片在线观看| 久久国产影院| 在线亚洲天堂| 午夜久久影院| 欧美调教sm| 亚洲精品国产精品乱码不99| 亚洲五月六月丁香激情| 91精品导航| 久久久久久久久久久久久久久久av| 深田咏美在线x99av| 国产精品玖玖玖在线资源| 久久精品30| 91精品国产欧美一区二区成人| 香蕉av一区| 国产精品不卡一区二区三区| 美女18一级毛片一品久道久久综合| 成年永久一区二区三区免费视频| 国产在线播放精品| 中文字幕+乱码+中文字幕一区| 超碰在线观看91| 国产欧美二区| 亚洲精品人成网在线播放影院| 看免费黄色录像| 人妻换人妻a片爽麻豆| 国产男女猛烈无遮挡免费视频| 手机看片日韩| 久久久久女人精品毛片九一| 91九色蝌蚪porny| 国产成人va亚洲电影| 老师让我她我爽了好久视频| www国产成人免费观看视频 深夜成人网| www夜片内射视频日韩精品成人| av在线网站免费观看| 18性欧美xxxⅹ性满足| 中文字幕一区二区5566日韩| 亚洲福利视频在线| 98精品国产高清在线xxxx天堂| 成年人国产精品| 91精品国产麻豆| 欧美理论电影在线播放| 国精产品一区一区三区四川| 日韩欧美电影一区二区| 精品美女一区| 中文字幕在线视频免费| 亚洲一区二区三区小说| 国产偷人妻精品一区二区在线| 白嫩少妇丰满一区二区| 老司机免费在线视频| 综合国产精品久久久| 在线国产视频| 国产aⅴ超薄肉色丝袜交足| xvideos国产在线视频| 国内视频在线精品| 777久久久精品| 可以免费看av的网址| 国产毛片一区二区| 国产国语**毛片高清视频| 国产欧美日韩一区| 国产一区二区精品久久91| 一本大道av伊人久久综合| 亚洲小说春色综合另类电影| 91一区二区三区四区| 日韩电影在线免费观看| 色在线视频网| 91久久综合| 在线日韩一区二区| 久久久精品视频在线| 爱爱的免费视频| 国产成人精品三级| 69国产精品视频免费观看| 国产成人精品亚洲精品| 小泽玛利亚av在线| 香蕉av在线播放| 日本亚洲欧洲色α| 色婷婷在线视频| 久久精品国产一区二区三区不卡| 日本特级黄色片| 久久9999久久免费精品国产| 中文字幕一区二区三区手机版| 亚洲欧洲综合在线| av不卡免费在线观看| www三级免费| 日韩一区二区在线看片| 又黄又爽的网站| 国产成人啪精品视频免费网| 午夜精品电影在线观看| 360天大佬第二季在线观看| 精品视频一区二区三区| 污视频网站免费观看| 欧美日韩国产高清| 亚洲av人无码激艳猛片服务器| 国产精品羞羞答答在线观看| 2欧美一区二区三区在线观看视频| 国产精品密蕾丝视频下载| 午夜精品一区二区三区在线观看| 女性隐私黄www网站视频| 亚洲日本精品视频| 国产免费福利视频| 国产精品yjizz| 国产1区2区3区在线| 国产乱淫a∨片免费观看| 久久综合图片| 欧美午夜精品理论片a级大开眼界| 久久久97精品| 国产精品 日韩| 99久久精品日本一区二区免费| 1024欧美极品| 在线视频欧美一区| 69精品视频| 影视先锋午夜av| 亚洲小视频在线观看| 日本1区2区| 国产精品情侣自拍| 欧美电影免费观看网站| 91.麻豆视频| 久久亚洲综合色| 久久精品亚洲精品国产欧美kt∨| 蜜桃av一区| 另类一区二区| 特级xxxxx欧美| 亚洲乱熟女一区二区| 国产寡妇色xxⅹ交肉视频| 91免费在线| 十大免费污污软件| 国产精品一区二区日韩| 蜜臀在线免费观看| 亚洲精品乱码久久久久久| 97精品一区二区| 日本aⅴ写真网站免费| 国产精品免费精品一区| 日本乱子伦xxxx| 欧美一区二区三区成人| 国内外成人激情视频| 亚洲欧洲成人在线| 正义之心1992免费观看全集完整版| 伊人久久大香线蕉综合75| 精品乱码一区二区三区四区| xxxxx在线观看| 久久久久亚洲av片无码下载蜜桃| 黄色av网站在线| 欧美黑人又粗又大又爽免费| www.久久av| 欧洲一区二区三区| 91精品黄色| 第一中文字幕在线| 久久精品久久精品久久| 成人h猎奇视频网站| 日韩av电影网| 色婷婷综合久久久久| 欧美日韩精品免费观看视频完整| 亚洲午夜精品久久久久久浪潮| 久久精品国产精品亚洲精品| 最近中文字幕免费mv视频多少集| 国产激情一区二区三区桃花岛亚洲| 精品深夜av无码一区二区老年| 免费 成 人 黄 色| 暖暖在线中文免费日本| 国产女主播在线一区二区| 高清一区二区三区日本久| 亚洲第一天堂在线观看| 久久人人爽人人片| 日韩精品一区二区三区四区五区| 欧美精品亚州精品| 91视频网址免费观看| 我想看黄色大片| 日韩在线视频导航| 久久久久国产精品免费免费搜索| 欧美精品一二区| 久久精品国产亚洲AV无码男同| 亚洲欧洲成人av每日更新| 樱桃视频免费看| 欧美亚日韩国产aⅴ精品中极品| 国产www网站| 男人天堂2024| 国产亚洲欧美日韩精品一区二区三区| 久久久精品国产99久久精品芒果| 五月天电影免费在线观看一区| 男人添女人下面高潮视频| 欧美在线制服丝袜| 日本午夜精品久久久| 精品午夜av| 精品亚洲一区二区三区在线播放| 亚洲视频免费观看| 色七七影院综合| 亚洲欧美清纯在线制服| 色狠狠久久av五月综合|| 中文字幕一区日韩电影| 四虎精品成人影院观看地址| 欧美人与动性xxxxx杂性| 免费在线观看视频a|