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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

深入理解 Lua 虚拟机

發(fā)布時(shí)間:2024/2/28 编程问答 61 豆豆
生活随笔 收集整理的這篇文章主要介紹了 深入理解 Lua 虚拟机 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

作者:nicochen,騰訊 IEG 游戲開發(fā)工程師

本文從一個(gè)簡(jiǎn)單示例入手,詳細(xì)講解 Lua 字節(jié)碼文件的存儲(chǔ)結(jié)構(gòu)及各字段含義,進(jìn)而引出 Lua 虛擬機(jī)指令集和運(yùn)行時(shí)的核心數(shù)據(jù)結(jié)構(gòu) Lua State,最后解釋 Lua 虛擬機(jī)的 47 條指令如何在 Lua State 上運(yùn)作的。

為了達(dá)到較高的執(zhí)行效率,lua 代碼并不是直接被 Lua 解釋器解釋執(zhí)行,而是會(huì)先編譯為字節(jié)碼,然后再交給 lua 虛擬機(jī)去執(zhí)行。lua 代碼稱為 chunk,編譯成的字節(jié)碼則稱為二進(jìn)制 chunk(Binary chunk)。lua.exe、wlua.exe 解釋器可直接執(zhí)行 lua 代碼(解釋器內(nèi)部會(huì)先將其編譯成字節(jié)碼),也可執(zhí)行使用 luac.exe 將 lua 代碼預(yù)編譯(Precompiled)為字節(jié)碼。使用預(yù)編譯的字節(jié)碼并不會(huì)加快腳本執(zhí)行的速度,但可以加快腳本加載的速度,并在一定程度上保護(hù)源代碼。luac.exe 可作為編譯器,把 lua 代碼編譯成字節(jié)碼,同時(shí)可作為反編譯器,分析字節(jié)碼的內(nèi)容。

luac.exe?-v??//?顯示luac的版本號(hào) luac.exe?Hello.lua??// 在當(dāng)前目錄下,編譯得到Hello.lua的二進(jìn)制chunk文件luac.out(默認(rèn)含調(diào)試符號(hào))luac.exe?-o?Hello.out?Hello1.lua?Hello2.lua?// 在當(dāng)前目錄下,編譯得到Hello1.lua和Hello2.lua的二進(jìn)制chunk文件Hello.out(默認(rèn)含調(diào)試符號(hào))luac.exe?-s?-o?d:\\Hello.out?Hello.lua??// 編譯得到Hello.lua的二進(jìn)制chunk文件d:\\Hello.out(去掉調(diào)試符號(hào))luac.exe?-p?Hello1.lua?Hello2.lua??// 對(duì)Hello1.lua和Hello2.lua只進(jìn)行語法檢測(cè)(注:只會(huì)檢查語法規(guī)則,不會(huì)檢查變量、函數(shù)等是否定義和實(shí)現(xiàn),函數(shù)參數(shù)返回值是否合法)

lua 編譯器以函數(shù)為單位對(duì)源代碼進(jìn)行編譯,每個(gè)函數(shù)會(huì)被編譯成一個(gè)稱之為原型(Prototype)的結(jié)構(gòu),原型主要包含 6 部分內(nèi)容:函數(shù)基本信息(basic info,含參數(shù)數(shù)量、局部變量數(shù)量等信息)、字節(jié)碼(bytecodes)、常量(constants)表、upvalue(閉包捕獲的非局部變量)表、調(diào)試信息(debug info)、子函數(shù)原型列表(sub functions)。

原型結(jié)構(gòu)使用這種嵌套遞歸結(jié)構(gòu),來描述函數(shù)中定義的子函數(shù):

注:lua 允許開發(fā)者可將語句寫到文件的全局范圍中,這是因?yàn)?lua 在編譯時(shí)會(huì)將整個(gè)文件放到一個(gè)稱之為 main 函數(shù)中,并以它為起點(diǎn)進(jìn)行編譯。

Hello.lua 源代碼如下:

print?("hello") function?add(a,?b)return?a+b end

編譯得到的 Hello.out 的二進(jìn)制為:

二進(jìn)制 chunk(Binary chunk)的格式并沒有標(biāo)準(zhǔn)化,也沒有任何官方文檔對(duì)其進(jìn)行說明,一切以 lua 官方實(shí)現(xiàn)的源代碼為準(zhǔn)。其設(shè)計(jì)并沒有考慮跨平臺(tái),對(duì)于需要超過一個(gè)字節(jié)表示的數(shù)據(jù),必須要考慮大小端(Endianness)問題。

lua 官方實(shí)現(xiàn)的做法比較簡(jiǎn)單:編譯 lua 腳本時(shí),直接按照本機(jī)的大小端方式生成二進(jìn)制 chunk 文件,當(dāng)加載二進(jìn)制 chunk 文件時(shí),會(huì)探測(cè)被加載文件的大小端方式,如果和本機(jī)不匹配,就拒絕加載。二進(jìn)制 chunk 格式設(shè)計(jì)也沒有考慮不同 lua 版本之間的兼容問題,當(dāng)加載二進(jìn)制 chunk 文件時(shí),會(huì)檢測(cè)其版本號(hào),如果和當(dāng)前 lua 版本不匹配,就拒絕加載。另外,二進(jìn)制 chunk 格式設(shè)計(jì)也沒有被刻意設(shè)計(jì)得很緊湊。在某些情況下,一段 lua 代碼編譯成二進(jìn)制 chunk 后,甚至?xí)晃谋拘问降脑创a還要大。預(yù)編譯成二進(jìn)制 chunk 主要是為了提升加載速度,因此這也不是很大的問題。

頭部字段

嵌套的函數(shù)原型

注 1:二進(jìn)制 chunk 中的字符串分為三種情況:

①NULL 字符串用 0x00 表示;

② 長(zhǎng)度小于等于 253(0xFD)的字符串,先用 1 個(gè) byte 存儲(chǔ)字符串長(zhǎng)度+1 的數(shù)值,然后是字節(jié)數(shù)組;

③ 長(zhǎng)度大于等于 254(0xFE)的字符串,第一個(gè)字節(jié)是 0xFF,后面跟一個(gè) 8 字節(jié) size_t 類型存儲(chǔ)字符串長(zhǎng)度+1 的數(shù)值,然后是字節(jié)數(shù)組。

注 2:常量 tag 對(duì)應(yīng)表

查看二進(jìn)制 chunk 中的所有函數(shù)(精簡(jiǎn)模式):

luac.exe -l Hello.lua

luac.exe -l Hello.out

注 1:每個(gè)函數(shù)信息包括兩個(gè)部分:前面兩行是函數(shù)的基本信息,后面是函數(shù)的指令列表。

注 2:函數(shù)的基本信息包括:函數(shù)名稱、函數(shù)的起始行列號(hào)、函數(shù)包含的指令數(shù)量、函數(shù)地址。函數(shù)的參數(shù) params 個(gè)數(shù)(0+表示函數(shù)為不固定參數(shù))、寄存器 slots 數(shù)量、upvalue 數(shù)量、局部變量 locals 數(shù)量、常量 constants 數(shù)量、子函數(shù) functions 數(shù)量。

注 3:指令列表里的每一條指令包含指令序號(hào)、對(duì)應(yīng)代碼行號(hào)、操作碼和操作數(shù)。分號(hào)后為 luac 生成的注釋,以便于我們理解指令。

注 4:整個(gè)文件內(nèi)容被放置到了 main 函數(shù)中,并以它作為嵌套起點(diǎn)。

查看二進(jìn)制 chunk 中的所有函數(shù)(詳細(xì)模式):

luac.exe -l -l Hello.lua ? 注:參數(shù)為 2 個(gè)-l

luac.exe -l -l Hello.out ? 注:詳細(xì)模式下,luac 會(huì)把常量表、局部變量表和 upvalue 表的信息也打印出來

main?<Test2.lua:0,0>?(6?instructions?at?0046e528) 0+?params,?2?slots,?1?upvalue,?0?locals,?3?constants,?1?function序號(hào)????代碼行????指令1???????[1]?????GETTABUP????????0?0?-1??;?_ENV?"print"???//GETTABUP?A?B?C??//將upvalues表索引為B:0的upvalue(即:_ENV)中key為常量表索引為C:-1的(即print),放到寄存器索引為A:0的地方2???????[1]?????LOADK???????????1?-2????;?"hello"??//LOADK?A?Bx??//將常量表索引為Bx:-2的hello加載到寄存器索引為A:1的地方3???????[1]?????CALL????????????0?2?1????;?//CALL?A?B?C??//調(diào)用寄存器索引為A:0的函數(shù),參數(shù)個(gè)數(shù)為B:2減1(即1個(gè)),C:1表示無返回值4???????[5]?????CLOSURE?????????0?0?????;?0046e728??????//CLOSURE?A?Bx??//將子函數(shù)原型列表索引為Bx:0的函數(shù)地址,放到寄存器索引為A:0的地方5???????[3]?????SETTABUP????????0?-3?0??;?_ENV?"add"???//SETTABUP?A?B?C??//將upvalues表索引為A:0的upvalue(即:_ENV)中key為常量表索引為B:-3(即add),設(shè)置為寄存器索引為C:0指向的值6???????[5]?????RETURN??????????0?1????????;?//RETURN?A?B???//B:1表示無返回值 constants?(3)?for?0046e528:序號(hào)????常量名1???????"print"2???????"hello"3???????"add" locals?(0)?for?0046e528: upvalues?(1)?for?0046e528:序號(hào)????upvalue名????是否為直接外圍函數(shù)的局部變量????在外圍函數(shù)調(diào)用幀的索引0???????_ENV????????1???????????????????????????????0function?<Test2.lua:3,5>?(3?instructions?at?0046e728) 2?params,?3?slots,?0?upvalues,?2?locals,?0?constants,?0?functions序號(hào)????代碼行????指令1???????[4]?????ADD?????????????2?0?1????;?//ADD?A?B?C??//將寄存器索引為0、1的兩個(gè)數(shù)相加得到的結(jié)果放到寄存器索引為2的地方2???????[4]?????RETURN??????????2?2????????;?//RETURN?A?B?//B:2表示有一個(gè)返回值??A:2表示返回值在寄存器索引為2的地方3???????[5]?????RETURN??????????0?1????????;?//RETURN?A?B?//B:1表示無返回值 constants?(0)?for?0046e728: locals?(2)?for?0046e728:寄存器索引????起始指令序號(hào)??終止指令序號(hào)??-1得到實(shí)際指令序號(hào)0???????a???????1???????4????????;?a變量的指令范圍為[0,?3],起始為0表示為傳入的參數(shù)變量1???????b???????1???????4????????;?b變量的指令范圍為[0,?3] upvalues?(0)?for?0046e728:

luac.exe -l -??// 從標(biāo)準(zhǔn)設(shè)備讀入腳本,輸完后按回車,然后按 Ctrl+Z 并回車,會(huì)打印出輸入內(nèi)容對(duì)應(yīng)的二進(jìn)制 chunk 內(nèi)容 ?? 注:進(jìn)入輸入模式后可按 Ctrl+C 強(qiáng)制退出

luac.exe -l --?// 使用上次輸入,打印出二進(jìn)制 chunk 內(nèi)容

luac.exe -l -l --?// 使用上次輸入,詳細(xì)模式下打印出二進(jìn)制 chunk 內(nèi)容(參數(shù)為 2 個(gè)-l)

Stack Based VM??vs Rigister?Based VM

高級(jí)編程語言的虛擬機(jī)是利用軟件技術(shù)對(duì)硬件進(jìn)行的模擬和抽象。按照實(shí)現(xiàn)方式,可分為兩類:基于棧(Stack Based)和基于寄存器(Rigister Based)。Java、.NET CLR、Python、Ruby、Lua5.0 之前的版本的虛擬機(jī)都是基于棧的虛擬機(jī);從 5.0 版本開始,Lua 的虛擬機(jī)改成了基于寄存器的虛擬機(jī)。

一個(gè)簡(jiǎn)單的加法賦值運(yùn)算:a=b+c

基于棧的虛擬機(jī),會(huì)轉(zhuǎn)化成如下指令:

push?b;?//?將變量b的值壓入stackpush?c;?//?將變量c的值壓入stackadd;?//?將stack頂部的兩個(gè)值彈出后相加,然后將結(jié)果壓入stack頂mov?a;?//?將stack頂部結(jié)果放到a中

所有的指令執(zhí)行,都是基于一個(gè)操作數(shù)棧的。你想要執(zhí)行任何指令時(shí),對(duì)不起,得先入棧,然后算完了再給我出棧。總的來說,就是抽象出了一個(gè)高度可移植的操作數(shù)棧,所有代碼都會(huì)被編譯成字節(jié)碼,然后字節(jié)碼就是在玩這個(gè)棧。好處是實(shí)現(xiàn)簡(jiǎn)單,移植性強(qiáng)。壞處是指令條數(shù)比較多,數(shù)據(jù)轉(zhuǎn)移次數(shù)比較多,因?yàn)槊恳淮稳霔3鰲6紶可鏀?shù)據(jù)的轉(zhuǎn)移。

基于寄存器的虛擬機(jī),會(huì)轉(zhuǎn)化成如下指令:

add?a?b?c;?//?將b與c對(duì)應(yīng)的寄存器的值相加,將結(jié)果保存在a對(duì)應(yīng)的寄存器中

沒有操作數(shù)棧這一概念,但是會(huì)有許多的虛擬寄存器。這類虛擬寄存器有別于 CPU 的寄存器,因?yàn)?CPU 寄存器往往是定址的(比如 DX 本身就是能存東西),而寄存器式的虛擬機(jī)中的寄存器通常有兩層含義:

(1)寄存器別名(比如 lua 里的 RA、RB、RC、RBx 等),它們往往只是起到一個(gè)地址映射的功能,它會(huì)根據(jù)指令中跟操作數(shù)相關(guān)的字段計(jì)算出操作數(shù)實(shí)際的內(nèi)存地址,從而取出操作數(shù)進(jìn)行計(jì)算;

(2)實(shí)際寄存器,有點(diǎn)類似操作數(shù)棧,也是一個(gè)全局的運(yùn)行時(shí)棧,只不過這個(gè)棧是跟函數(shù)走的,一個(gè)函數(shù)對(duì)應(yīng)一個(gè)棧幀,棧幀里每個(gè) slot 就是一個(gè)寄存器,第 1 步中通過別名映射后的地址就是每個(gè) slot 的地址。

好處是指令條數(shù)少,數(shù)據(jù)轉(zhuǎn)移次數(shù)少。壞處是單挑指令長(zhǎng)度較長(zhǎng)。具體來看,lua 里的實(shí)際寄存器數(shù)組是用 TValue 結(jié)構(gòu)的棧來模擬的,這個(gè)棧也是 lua 和 C 進(jìn)行交互的虛擬棧。

lua 指令集

Lua 虛擬機(jī)的指令集為定長(zhǎng)(Fixed-width)指令集,每條指令占 4 個(gè)字節(jié)(32bits),其中操作碼(OpCode)占 6bits,操作數(shù)(Operand)使用剩余的 26bits。Lua5.3 版本共有 47 條指令,按功能可分為 6 大類:常量加載指令、運(yùn)算符相關(guān)指令、循環(huán)和跳轉(zhuǎn)指令、函數(shù)調(diào)用相關(guān)指令、表操作指令和 Upvalue 操作指令。

按編碼模式分為 4 類:iABC(39)、iABx(3)、iAsBx(4)、iAx(1)

4 種模式中,只有 iAsBx 下的 sBx 操作數(shù)會(huì)被解釋成有符號(hào)整數(shù),其他情況下操作數(shù)均被解釋為無符號(hào)整數(shù)。操作數(shù) A 主要用來表示目標(biāo)寄存器索引,其他操作數(shù)按表示信息可分為 4 種類型:OpArgN、OpArgU、OpArgR、OpArgK:

Lua 棧索引

注 1:絕對(duì)索引是從 1 開始由棧底到棧頂依次增長(zhǎng)的;

注 2:相對(duì)索引是從-1 開始由棧頂?shù)綏5滓来芜f減的(在 lua API 函數(shù)內(nèi)部會(huì)將相對(duì)索引轉(zhuǎn)換為絕對(duì)索引);

注 3:上圖棧的容量為 7,棧頂絕對(duì)索引為 5,有效索引范圍為:[1,5],可接受索引范圍為:[1, 7];

注 4:Lua 虛擬機(jī)指令里寄存器索引是從 0 開始的,而 Lua API 里的棧索引是從 1 開始的,因此當(dāng)需要把寄存器索引當(dāng)成棧索引使用時(shí),要進(jìn)行+1。

Lua State

指令表

下面是 Lua 的 47 條指令詳細(xì)說明:

B:1?C?A:3 MOVE

把源寄存器(索引由 B 指定)里的值移動(dòng)到目標(biāo)寄存器(索引有 A 指定),常用于局部變量賦值和參數(shù)傳遞。

公式:R(A) := R(B)

Bx:2 A:4 LOADK

給單個(gè)寄存器(索引由 A 指定)設(shè)置成常量(其在常量表的索引由 Bx 指定),將常量表里的某個(gè)常量加載到指定寄存器。

在 lua 中,數(shù)值型、字符串型等局部變量賦初始值 (數(shù)字和字符串會(huì)放到常量表中):

公式:R(A) := Kst(Bx)

Bx A:4 LOADKX

Ax:585028?EXTRAARG

LOADK 使用 Bx(18bits,最大無符號(hào)整數(shù)為 262143)表示常量表索引。當(dāng)將 lua 作數(shù)據(jù)描述語言使用時(shí),常量表可能會(huì)超過這個(gè)限制,為了應(yīng)對(duì)這種情況,lua 提供了 LOADKX 指令。LOADKX 指令需要和 EXTRAAG 指令搭配使用,用后者的 Ax(26bits)操作數(shù)來指定常量索引。

公式:R(A) := Kst(Ax)

指令名稱類型操作碼BCA
LOADBOOLiABC0x03OpArgUOpArgU目標(biāo)寄存器 idx

B:0 C:1 A:2 LOADBOOL

給單個(gè)寄存器(索引由 A 指定)設(shè)置布爾值(布爾值由 B 指定),如果寄存器 C 為非 0 則跳過下一條指令。

公式:

R(A) := (bool)B

if(C) pc++

指令名稱類型操作碼BCA
LOADNILiABC0x04OpArgUOpArgN目標(biāo)寄存器 idx

B:4 C A:0 LOADNIL

將序號(hào)[A,A+B]連續(xù) B+1 個(gè)寄存器設(shè)置成 nil 值,用于給連續(xù) n 個(gè)寄存器放置 nil 值。在 lua 中,局部變量的默認(rèn)初始值為 nil,LOADNIL 指令常用于給連續(xù) n 個(gè)局部變量設(shè)置初始值。

公式:R(A), R(A+1), ... ,R(A+B) := nil

指令名稱類型操作碼BCA
GETUPVALiABC0x05OpArgUOpArgN目標(biāo)寄存器 idx

B:1 C A:3 GETUPVAL

把當(dāng)前閉包的某個(gè) Upvalue 值(索引由 B 指定)拷貝到目標(biāo)寄存器(索引由 A 指定)中 ?。

公式:R(A) := Upvalue[B]

指令名稱類型操作碼BCA
GETTABUPiABC0x06OpArgUOpArgK目標(biāo)寄存器 idx

B:0 C:0x002 A:3 GETTABUP

把當(dāng)前閉包的某個(gè) Upvalue 值(索引由 B 指定)拷貝到目標(biāo)寄存器(索引由 A 指定)中,與 GETUPVAL 不同的是,Upvalue 從表里取值(鍵由 C 指定,為寄存器或常量表索引)。

R(A) := Upvalue[B][rk(c)]

指令名稱類型操作碼BCA
GETTABLEiABC0x07OpArgROpArgK目標(biāo)寄存器 idx

B:0 C:0x002 A:3 GETTABLE

把表中某個(gè)值拷貝到目標(biāo)寄存器(索引由 A 指定)中,表所在寄存器索引由 B 指定,鍵由 C(為寄存器或常量表索引)指定。

公式:R(A) := R[B][rk(c)]

指令名稱類型操作碼BCA
SETTABUPiABC0x08OpArgKOpArgK目標(biāo)寄存器 idx

B:0x002 C:0x003 A:0?SETTABUP

設(shè)置當(dāng)前閉包的某個(gè) Upvalue 值(索引由 A 指定)為寄存器或常量表的某個(gè)值(索引由 C 指定),與 SETUPVAL 不同的是,Upvalue 從表里取值(鍵由 B 指定,為寄存器或常量表索引)。

Upvalue[A][rk(b)] := RK(C)

指令名稱類型操作碼BCA
SETUPVALiABC0x09OpArgUOpArgN目標(biāo)寄存器 idx

B:0 C A:3 SETUPVAL

設(shè)置當(dāng)前閉包的某個(gè) Upvalue 值(索引由 B 指定)為寄存器的某個(gè)值(索引由 A 指定)。

公式:Upvalue[B] := R(A)

指令名稱類型操作碼BCA
SETTABLEiABC0x0AOpArgKOpArgK目標(biāo)寄存器 idx

B:0x002 C:0x003 A:1 SETTABLE

給寄存器中的表(索引由 A 指定)的某個(gè)鍵進(jìn)行賦值,鍵和值分別由 B 和 C 指定(為寄存器或常量表索引)。

公式:R(A)[RK(B)] := RK(C)

指令名稱類型操作碼BCA
NEWTABLEiABC0x0BOpArgUOpArgU目標(biāo)寄存器 idx

B:0 C:2 A:4 NEWTABLE

創(chuàng)建空表,并將其放入指定寄存器(索引有 A 指定),表的初始數(shù)組容量和哈希表容量分別有 B 和 C 指定。

公式:R(A) := {} (size = B, C)

指令名稱類型操作碼BCA
SELFiABC0x0COpArgROpArgK目標(biāo)寄存器 idx

B:1 C:0x100 A:2 SELF

把寄存器中對(duì)象(索引由 B 指定)和常量表中方法(索引由 C 指定)拷貝到相鄰的兩個(gè)目標(biāo)寄存器中,起始目標(biāo)寄存器的索引由 A 指定。

公式:

R(A+1) := R(B)

R(A) := R(B)[RK(C)]

指令名稱類型操作碼BCA
ADDiABC0x0DOpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 ADD

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行相加,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) + RK(C)

指令名稱類型操作碼BCA
SUBiABC0x0EOpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 SUB

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行相減,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)

公式:

R(A) := RK(B) - RK(C)

指令名稱類型操作碼BCA
MULiABC0x0FOpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 MUL

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行相乘,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) * RK(C)

指令名稱類型操作碼BCA
MODiABC0x10OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 MOD

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行求摸運(yùn)算,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) % RK(C)

指令名稱類型操作碼BCA
POWiABC0x11OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 POW

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行求冪運(yùn)算,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) ^ RK(C)

指令名稱類型操作碼BCA
DIViABC0x12OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 DIV

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行相除,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) / RK(C)

指令名稱類型操作碼BCA
IDIViABC0x13OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 IDIV

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行相整除,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) // RK(C)

指令名稱類型操作碼BCA
BANDiABC0x14OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 BAND

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行求與操作,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) & RK(C)

指令名稱類型操作碼BCA
BORiABC0x15OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 BOR

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行求或操作,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) | RK(C)

指令名稱類型操作碼BCA
BXORiABC0x16OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 BXOR

對(duì)兩個(gè)寄存器或常量值(索引由 B 和 C 指定)進(jìn)行求異或操作,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)

公式:R(A) := RK(B) ~ RK(C)

指令名稱類型操作碼BCA
SHLiABC0x17OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 SHL

索引由 B 指定的寄存器或常量值進(jìn)行左移位操作(移動(dòng)位數(shù)的索引由 C 指定的寄存器或常量值),并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) << RK(C)

指令名稱類型操作碼BCA
SHRiABC0x18OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:4 SHR

索引由 B 指定的寄存器或常量值進(jìn)行右移位操作(移動(dòng)位數(shù)的索引由 C 指定的寄存器或常量值),并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := RK(B) >> RK(C)

指令名稱類型操作碼BCA
UNMiABC0x19OpArgROpArgN目標(biāo)寄存器 idx

B:1 C A:3 UNM

對(duì)寄存器(索引由 B 指定)進(jìn)行取負(fù)數(shù)操作,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := - R(B)

指令名稱類型操作碼BCA
BNOTiABC0x1AOpArgROpArgN目標(biāo)寄存器 idx

B:1 C A:3 BNOT

對(duì)寄存器(索引由 B 指定)進(jìn)行取反操作,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := ~ R(B)

指令名稱類型操作碼BCA
NOTiABC0x1BOpArgROpArgN目標(biāo)寄存器 idx

B:1 C A:3 NOT

對(duì)寄存器(索引由 B 指定)進(jìn)行求非操作,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := not R(B)

指令名稱類型操作碼BCA
LENiABC0x1COpArgROpArgN目標(biāo)寄存器 idx

B:1 C A:3 LEN

對(duì)寄存器(索引由 B 指定)進(jìn)行求長(zhǎng)度操作,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := length of R(B)

指令名稱類型操作碼BCA
CONCATiABC0x1DOpArgROpArgR目標(biāo)寄存器 idx

B:2 C:4 A:1 CONCAT

將連續(xù) n 個(gè)寄存器(起始索引和終止索引由 B 和 C 指定)里的值進(jìn)行拼接,并將結(jié)果放入另一個(gè)寄存器中(索引由 A 指定)。

公式:R(A) := R(B) .. ... .. R(C)

指令名稱類型操作碼sBxA
JMPiAsBx0x1EOpArgR目標(biāo)寄存器 idx

sBx:-1 A JMP

當(dāng) sBx 不為 0 時(shí),進(jìn)行無條件跳轉(zhuǎn),執(zhí)行 pc = pc + sBx(sBx 為-1,表示將當(dāng)前指令再執(zhí)行一次 ? 注:這將是一個(gè)死循環(huán))

sBx:0 A:0x001 JMP;

當(dāng) sBx 為 0 時(shí)(繼續(xù)執(zhí)行后面指令,不跳轉(zhuǎn)),用于閉合處于開啟狀態(tài)的 Upvalue(即:把即將銷毀的局部變量的值復(fù)制出來,并更新到某個(gè) Upvalue 中)。

當(dāng)前閉包的某個(gè) Upvalue 值的索引由 A 指定:

指令名稱類型操作碼BCA
EQiABC0x1FOpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:1 EQ

寄存器或常量表(索引由 B 指定)是否等于寄存器或常量表(索引由 C 指定),若結(jié)果等于操作數(shù) A,則跳過下一條指令。

公式:if ((RK(B) == RK(C)) pc++

指令名稱類型操作碼BCA
LTiABC0x20OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:1 LT

寄存器或常量表(索引由 B 指定)是否小于寄存器或常量表(索引由 C 指定),若結(jié)果等于操作數(shù) A,則跳過下一條指令。

公式:if ((RK(B) < RK(C)) pc++

指令名稱類型操作碼BCA
LEiABC0x21OpArgKOpArgK目標(biāo)寄存器 idx

B:0x001 C:0x100 A:1 LE

寄存器或常量表(索引由 B 指定)是否小于等于寄存器或常量表(索引由 C 指定),若結(jié)果等于操作數(shù) A,則跳過下一條指令。

公式:if ((RK(B) <= RK(C)) pc++

指令名稱類型操作碼BCA
TESTiABC0x22OpArgNOpArgU目標(biāo)寄存器 idx

B C:0 A:1 TEST

判斷寄存器(索引由 A 指定)中的值轉(zhuǎn)換為 bool 值后,是否和操作數(shù) C 表示的 bool 值一致,若結(jié)果不一致,則跳過下一條指令。

公式:

if not (R(A) <=> C) pc++

注:<=>表示按 bool 值比較

指令名稱類型操作碼BCA
TESTSETiABC0x23OpArgROpArgU目標(biāo)寄存器 idx

B:3? C:0 A:1 TESTSET

判斷寄存器(索引由 B 指定)中的值轉(zhuǎn)換為 bool 值后,是否和操作數(shù) C 表示的 bool 值一致,若結(jié)果一致,將寄存器(索引由 B 指定)中的值復(fù)制到寄存器中(索引由 A 指定),否則跳過下一條指令。

公式:

if?(R(B)?\<=\>?C)R(A)?:=?R(B) elsepc++?

注:<=>表示按 bool 值比較

指令名稱類型操作碼BCA
CALLiABC0x24OpArgUOpArgU目標(biāo)寄存器 idx

B:5 C:4 A:0 CALL

被調(diào)用函數(shù)位于寄存器中(索引由 A 指定),傳遞給被調(diào)用函數(shù)的參數(shù)值也在寄存器中,緊挨著被調(diào)用函數(shù),參數(shù)個(gè)數(shù)為操作數(shù) B 指定。

① B==0,接受其他函數(shù)全部返回來的參數(shù)

② B>0,參數(shù)個(gè)數(shù)為 B-1

函數(shù)調(diào)用結(jié)束后,原先存放函數(shù)和參數(shù)值的寄存器會(huì)被返回值占據(jù),具體多少個(gè)返回值由操作數(shù) C 指定。

① C==0,將返回值全部返回給接收者

② C==1,無返回值

③ C>1,返回值的數(shù)量為 C-1

公式:R(A), ... ,

指令名稱類型操作碼BCA
TAILCALLiABC0x25OpArgUOpArgU目標(biāo)寄存器 idx

函數(shù)調(diào)用一般通過調(diào)用棧來實(shí)現(xiàn)。用這種方法,每調(diào)用一個(gè)函數(shù)都會(huì)產(chǎn)生一個(gè)調(diào)用幀。

如果調(diào)用層次太深(如遞歸),容易導(dǎo)致棧溢出。尾遞歸優(yōu)化則可以讓我們發(fā)揮遞歸函數(shù)調(diào)用威力的同時(shí),避免調(diào)用棧溢出。利用這種優(yōu)化,被調(diào)函數(shù)可以重用主調(diào)函數(shù)的調(diào)用幀,因此可有效緩解調(diào)用棧溢出癥狀。不過該優(yōu)化只適合某些特定情況。

如:return f(args) 會(huì)被編譯器優(yōu)化成 TAILCALL 指令,公式:return R(A)(R(A+1), ... , R(A+B-1))

指令名稱類型操作碼BCA
RETURNiABC0x26OpArgUOpArgN目標(biāo)寄存器 idx

B:4 C? A:2 RETURN

把存放在連續(xù)多個(gè)寄存器里的值返回給父函數(shù),其中第一個(gè)寄存器的索引由操作數(shù) A 指定,寄存器數(shù)量由操作數(shù) B 指定,操作數(shù) C 沒有使用,需要將返回值推入棧頂:

① B==1,不需要返回任何值

② B > 1,需要返回 B-1 個(gè)值;這些值已經(jīng)在寄存器中了,只用再將它們復(fù)制到棧頂即可

③ B==0,一部分返回值已經(jīng)在棧頂了,只需將另一部分也推入棧頂即可

公式:return R(A),...,R(A+B-2)

指令名稱類型操作碼sBxA
FORLOOPiAsBx0x27OpArgR目標(biāo)寄存器 idx

數(shù)值 for 循環(huán):用于按一定步長(zhǎng)遍歷某個(gè)范圍內(nèi)的數(shù)值 ? 如:for i=1,100,2 ?do ?f()? end // 初始值為 1,步長(zhǎng)為 2,上限為 100

該指令先給 i 加上步長(zhǎng),然后判斷 i 是否在范圍之內(nèi)。若已經(jīng)超出范圍,則循環(huán)結(jié)束;若為超出范圍,則將數(shù)值拷貝給用戶定義的局部變量,然后跳轉(zhuǎn)到循環(huán)體內(nèi)部開始執(zhí)行具體的代碼塊。

公式:

R(A)?+=?R(A+2) if?R(A)?<?=?R(A+1)pc+=sBxR(A+3)=R(A)

注:當(dāng)步長(zhǎng)為正數(shù)時(shí)<?=為<=

當(dāng)步長(zhǎng)為負(fù)數(shù)時(shí)<?=為>=

指令名稱類型操作碼sBxA
FORPREPiAsBx0x28OpArgR目標(biāo)寄存器 idx

數(shù)值 for 循環(huán):用于按一定步長(zhǎng)遍歷某個(gè)范圍內(nèi)的數(shù)值 ? 如:for i=1,100,2 ?do ?f()? end // 初始值為 1,步長(zhǎng)為 2,上限為 100。

該指令的目的是在循環(huán)之前預(yù)先將 i 減去步長(zhǎng)(得到-1),然后跳轉(zhuǎn)到 FORLOOP 指令正式開始循環(huán):

公式:

R(A)-=R(A+2)

pc+=sBx

指令名稱類型操作碼BCA
TFORCALLiABC0x29OpArgNOpArgU目標(biāo)寄存器 idx

通用 for 循環(huán):for k,v in pairs(t) do print(k,v) end

編譯器使用的第一個(gè)特殊變量(generator):f 存放的是迭代器,其他兩個(gè)特殊變量(state):s、(control):var 來調(diào)用迭代器,把結(jié)果保存在用戶定義的變量 k、v 中。

公式:R(A+3),...,R(A+2+C) := R(A)(R(A+1),R(A+2))

指令名稱類型操作碼sBxA
TFORLOOPiAsBx0x2AOpArgR目標(biāo)寄存器 idx

通用 for 循環(huán):for k,v in pairs(t) do print(k,v) end

若迭代器返回的第一個(gè)值(變量 k)不是 nil,則把該值拷貝到(control):var,然后跳轉(zhuǎn)到循環(huán)體;若為 nil,則循環(huán)結(jié)束。

公式:

if R(A+1) ~= nil

R(A)=R(A+1)

pc+=sBx

指令名稱類型操作碼BCA
SETLISTiABC0x2BOpArgUOpArgU目標(biāo)寄存器 idx

SETTABLE 是通用指令,每次只處理一個(gè)鍵值對(duì),具體操作交給表去處理,并不關(guān)心實(shí)際寫入的是表的 hash 部分還是數(shù)組部分。SETLIST 則是專門給數(shù)組準(zhǔn)備的,用于按索引批量設(shè)置數(shù)組元素。其中數(shù)組位于寄存器中,索引由操作數(shù) A 指定;需要寫入數(shù)組的一系列值也在寄存器中,緊挨著數(shù)組,數(shù)量由操作數(shù) B 指定;數(shù)組起始索引則由操作數(shù) C 指定。

因?yàn)?C 操作數(shù)只有 9bits,所以直接用它表示數(shù)組索引顯然不夠用。這里解決辦法是讓 C 操作數(shù)保存批次數(shù),然后用批次數(shù)乘上批大小(FPF,默認(rèn)為 50)就可以算出數(shù)組的起始索引。因此,C 操作數(shù)能表示的最大索引為 25600(50*512),當(dāng)數(shù)組長(zhǎng)度大于 25600 時(shí),SETLIST 指令后會(huì)跟一條 EXTRAARG 指令,用其 Ax 操作數(shù)來保存批次數(shù)。

綜上,C>0,表示的是批次數(shù)+1,否則,真正批次數(shù)存放在后續(xù)的 EXTRAARG 指令中。

操作數(shù) B 為 0 時(shí),當(dāng)表構(gòu)造器的最后一個(gè)元素是函數(shù)調(diào)用或者 vararg 表達(dá)式時(shí),Lua 會(huì)把它們產(chǎn)生的所有值都收集起來供 SETLIST 使用。

公式:

R(A)[(C-1)*FPF+i] := R(A+i)

1 <= i <= B

指令名稱類型操作碼BxA
CLOSUREiABx0x2COpArgU目標(biāo)寄存器 idx

把當(dāng)前 Lua 函數(shù)的子函數(shù)原型實(shí)例化為閉包,放入由操作數(shù) A 指定的寄存器中子函數(shù)原型來自于當(dāng)前函數(shù)原型的子函數(shù)原型表,索引由操作數(shù) Bx 指定。

下圖為將 prototypes 表中索引為 1 的 g 子函數(shù),放入索引為 4 的寄存器中:

公式:R(A) := closure(KPROTO[Bx])

指令名稱類型操作碼BCA
VARARGiABC0x2DOpArgUOpArgN目標(biāo)寄存器 idx

把傳遞給當(dāng)前函數(shù)的變長(zhǎng)參數(shù)加載到連續(xù)多個(gè)寄存器中。

其中第一個(gè)寄存器的索引由操作數(shù) A 指定,寄存器數(shù)量由操作數(shù) B 指定,操作數(shù) C 沒有使用,操作數(shù) B 若大于 1,表示把 B-1 個(gè) vararg 參數(shù)復(fù)制到寄存器中,否則只能等于 0。

公式:R(A),R(A+1),...R(A+B-2)=vararg

指令名稱類型操作碼Ax
EXTRAARGiAx0x2EOpArgU

Ax:67108864 EXTRAARG

Ax 有 26bits,用來指定常量索引,可存放最大無符號(hào)整數(shù)為 67108864,可滿足大部分情況的需要了。

參考

  • 《自己動(dòng)手實(shí)現(xiàn) Lua》源代碼

  • Lua 設(shè)計(jì)與實(shí)現(xiàn)--虛擬機(jī)篇

  • Lua 5.3 Bytecode Reference?

  • Lua 源碼解析??

超強(qiáng)干貨來襲 云風(fēng)專訪:近40年碼齡,通宵達(dá)旦的技術(shù)人生

總結(jié)

以上是生活随笔為你收集整理的深入理解 Lua 虚拟机的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

欧美日韩国产高清视频 | 久久99热精品这里久久精品 | 菠萝菠萝蜜在线播放 | 色资源二区在线视频 | 国产麻豆剧传媒免费观看 | 黄色av一级片| 日韩久久久久久久久久 | 在线免费黄 | 日韩大片在线观看 | 日韩区视频 | 中文字幕第一页在线视频 | 国产精品女同一区二区三区久久夜 | 婷婷免费视频 | 夜夜看av | wwwww.国产 | 五月天久久狠狠 | 亚洲精品女人久久久 | 久久不射网站 | 欧女人精69xxxxxx | 在线视频一二三 | www久草| 成人黄色一级视频 | 天天色影院 | 亚洲极色| 日韩av高清| 97色狠狠 | 免费成人在线观看视频 | 96精品高清视频在线观看软件特色 | 日韩av高清在线观看 | 99精彩视频在线观看免费 | 97国产大学生情侣酒店的特点 | 天天操天天艹 | 三级av免费观看 | 欧美日本不卡 | 国产精品成人国产乱一区 | 五月香婷| 成人在线免费观看网站 | 亚洲成av人片在线观看无 | 亚洲视频免费在线观看 | 狠狠操狠狠干2017 | 亚洲国产日本 | 国产精品综合在线观看 | 国产麻豆电影在线观看 | 国产色综合 | 激情一区二区三区欧美 | 最新成人在线 | 欧美xxxxx在线视频 | a在线免费观看视频 | 五月婷婷综合在线视频 | 在线中文日韩 | 中文字幕国内精品 | 成人精品国产免费网站 | 亚洲精品资源 | 日韩av电影一区 | 成人动图 | 欧美精品久久久久久久免费 | 91人人爽久久涩噜噜噜 | 91大神精品视频在线观看 | 国产精品日韩欧美 | 精品在线一区二区三区 | 国产一区在线不卡 | 日韩欧美高清免费 | 日韩免费视频在线观看 | 91av99| 制服丝袜一区二区 | 成人av电影免费在线观看 | 天堂av免费看 | av免费线看 | 久久免费a | 成人精品国产免费网站 | 亚洲国产中文字幕在线观看 | 日韩免费精品 | 色91av| 日韩高清成人在线 | 亚洲精品tv| 久久在线精品 | 天天躁日日躁狠狠躁 | 欧美最新大片在线看 | 国产一级做a爱片久久毛片a | 狠狠色丁香婷综合久久 | 在线观看www视频 | 天天操夜 | 亚洲欧美视频在线观看 | 日韩三级一区 | 国产午夜精品免费一区二区三区视频 | 日韩av不卡在线播放 | 日本公妇在线观看 | 国产精品片 | 久久国产一区二区三区 | 国产精品专区在线 | 亚洲国产精品久久 | 国产伦理久久精品久久久久_ | 在线免费视频a | 国产专区在线播放 | 美女国产免费 | 国产精品久久人 | 精品国产一区二区三区不卡 | 免费av观看| 黄色大片入口 | 国产视频999 | 日韩偷拍精品 | 国产一级片网站 | 在线观看国产麻豆 | 亚洲国产一区在线观看 | 狠狠操在线 | 97国产情侣爱久久免费观看 | 麻豆超碰| 九九视频精品免费 | 欧美网站黄色 | 狠狠色丁香婷婷综合 | 日日夜夜精品网站 | 亚洲视频一区二区三区在线观看 | 中国一级片在线观看 | 久久亚洲成人网 | 国产精品一区二区你懂的 | 免费观看的av网站 | 五月花激情 | 色多多视频在线 | 在线色亚洲 | 黄色www免费| 国产精品久久久久久久久久久免费看 | 日本黄色大片免费看 | 波多野结衣精品 | 国产精品久久久久久久久蜜臀 | 色就干| 在线看片一区 | 日韩精品中文字幕久久臀 | 国内免费的中文字幕 | 亚洲国产人午在线一二区 | 男女免费视频观看 | 欧美日韩中文在线 | 久久国产精品99久久人人澡 | 91免费网站在线观看 | 天天做日日爱夜夜爽 | 四虎成人精品永久免费av | 国产自产高清不卡 | 欧美日韩国产一区 | 国产原厂视频在线观看 | 国产亚洲精品美女久久 | 欧美日韩一级在线 | 成人av在线直播 | 天天爽天天射 | 精品成人网 | 国产一区免费在线观看 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 国产又粗又猛又色又黄视频 | 日韩av不卡在线 | 国产毛片aaa | 国产视频久久久 | 91精品国自产在线偷拍蜜桃 | 国产精品美女久久久久久久 | 久久久久久久久久国产精品 | 欧美成人精品欧美一级乱黄 | 国内精品久久久久影院优 | 天天狠狠干 | 久久96国产精品久久99软件 | 精品国产一区二 | 亚洲精品国产精品久久99 | 亚洲女裸体 | 黄色av观看 | 欧美孕交vivoestv另类 | 97精品国产91久久久久久 | 色姑娘综合网 | 91免费观看网站 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 免费在线91 | 69性欧美| 国产成人av片 | 九九视频免费观看视频精品 | 久久久久一区二区三区 | 999精品| 97国产精品亚洲精品 | 欧美日韩xxxxx | 狠狠久久 | 免费a级大片 | www在线观看国产 | 在线观看成人国产 | 亚洲精品在线网站 | 国产一级a毛片视频爆浆 | 久久久久久久国产精品 | 99人久久精品视频最新地址 | 精品亚洲视频在线观看 | 亚洲男女精品 | 欧美精品久久久久久久久久白贞 | 国产明星视频三级a三级点| 日日综合网 | 91午夜精品 | 日韩在观看线 | 在线看成人 | 天天插天天爱 | 伊人色综合久久天天 | 精品久久久久一区二区国产 | av电影不卡在线 | 日韩免费av片 | 四虎影视av| 免费一级日韩欧美性大片 | 999电影免费在线观看2020 | 亚洲自拍av在线 | 久久av观看| 六月丁香六月婷婷 | 久久精品99国产精品日本 | 亚洲春色奇米影视 | 国产黄a三级三级三级三级三级 | 日本精品久久久久中文字幕 | 国产精品专区在线观看 | 在线观看av中文字幕 | 日日操夜夜操狠狠操 | 成人午夜在线观看 | 亚洲三级黄色 | 成人黄色电影在线观看 | 久久久官网| 四虎影视8848aamm| 天天爽天天做 | 人人爽久久久噜噜噜电影 | 黄色www免费 | 国产在线探花 | 免费在线观看av片 | 国产精品久久久久亚洲影视 | 日韩精品中文字幕一区二区 | 69国产精品成人在线播放 | 成人亚洲免费 | ,久久福利影视 | 国产精品免费观看久久 | 国产精品久久久久三级 | 91中文在线视频 | 天天色天天色天天色 | 97激情影院 | 欧洲精品视频一区 | 亚洲欧美日韩国产精品一区午夜 | 一本一本久久a久久精品综合妖精 | 日韩在线观看第一页 | 高清在线一区二区 | 国产一区在线观看免费 | 国产一级在线播放 | 久久国产精品影视 | 国产精品久久久区三区天天噜 | 欧美日韩xxxxx| 欧美日韩在线观看不卡 | 午夜av片 | 午夜精品久久久久久久99婷婷 | 中文字幕在线看 | 狠狠综合 | 久久最新| 欧美激情在线网站 | 国产在线免费观看 | 国产精品久久久久国产精品日日 | 久久高清精品 | 97在线观看免费 | 久久久久国产一区二区三区四区 | 中文字幕精品一区二区精品 | av专区在线 | 久久伊人精品天天 | 五月天婷婷在线播放 | 二区三区毛片 | 日韩天天综合 | 国产精品成人aaaaa网站 | 91福利区一区二区三区 | 黄色软件视频网站 | 国产精品理论片 | 在线观看成人 | 人人爽人人爽 | 成人性生交大片免费观看网站 | 婷婷成人在线 | 欧美日韩一区二区三区视频 | 嫩模bbw搡bbbb搡bbbb | 视频在线观看91 | 日韩av二区 | a视频免费 | 在线观看国产高清视频 | 欧美日韩视频一区二区三区 | 久久免费在线 | 欧美一区二区三区在线视频观看 | 午夜视频色 | 日韩动态视频 | 日韩高清精品免费观看 | 成人 国产 在线 | 黄色毛片视频免费观看中文 | 婷婷成人综合 | 黄色www免费 | 草久在线观看 | 久久久国产精品一区二区三区 | 五月综合在线观看 | 午夜精品电影一区二区在线 | 国产精品午夜免费福利视频 | 一区二区三区在线免费观看视频 | 中文字幕一区三区 | 四虎影视成人永久免费观看亚洲欧美 | 久久久精品 一区二区三区 国产99视频在线观看 | 亚洲va欧美va人人爽春色影视 | 免费三级黄色 | av超碰在线| 国产又粗又猛又爽又黄的视频先 | 久久国产一区二区 | 九九久久久久久久久激情 | 亚州精品在线视频 | 99av在线视频 | 91视频成人免费 | 日韩av在线高清 | 国产精品第72页 | 精品国产一二区 | 国产日产精品一区二区三区四区 | 在线观看理论 | 中文av不卡| 天天摸天天舔天天操 | 91日韩国产| 日韩精品资源 | 久久国产精品成人免费浪潮 | 在线免费观看一区二区三区 | 亚洲在线日韩 | 人人视频网站 | 在线观看不卡的av | 夜色资源站wwwcom | 日韩在线欧美在线 | 麻豆视频免费网站 | 少妇bbb搡bbbb搡bbbb′ | 天天综合视频在线观看 | 96久久精品 | 探花视频在线观看 | 精品影院| 精品五月天 | 国产精品一区专区欧美日韩 | 午夜精品久久久久久99热明星 | 97视频久久久 | 99久久这里只有精品 | 视频一区二区精品 | 在线视频app | 久久午夜电影网 | 精品国产乱码久久久久久1区2匹 | 丁香九月婷婷 | 天天天天天天天天操 | 五月天综合婷婷 | 一区二区电影网 | 狠狠色丁香九九婷婷综合五月 | 在线观看中文字幕视频 | 国产日韩欧美在线影视 | 香蕉网在线播放 | 中文av一区二区 | 国产精品国产精品 | 西西444www大胆高清视频 | 色中文字幕在线观看 | 国产一级黄色电影 | 亚洲第一av在线 | 免费日韩高清 | 久久看免费视频 | 欧美福利视频 | av中文字幕av | 黄色网址中文字幕 | 免费观看成人 | 激情婷婷久久 | 激情自拍av | 观看免费av| 乱子伦av| 91精品国产成 | 在线岛国av | 国产分类视频 | 99精品免费久久久久久久久日本 | 国产在线观看91 | 黄色1级大片 | 国产色a在线观看 | 国产一区二区中文字幕 | 国产黄色片免费观看 | 99视频精品 | 久久草视频 | 久草精品视频在线播放 | 中文字幕av免费在线观看 | 天天摸夜夜添 | 久久国产99 | 成人在线观看你懂的 | 免费观看版 | 天天操夜夜逼 | 日韩日韩日韩日韩 | 操一草 | 日韩欧美在线观看一区二区三区 | 婷婷五天天在线视频 | 国产黄色av影视 | 久久综合九色综合97_ 久久久 | 日日碰狠狠添天天爽超碰97久久 | 成人一级电影在线观看 | 久久久久久久久久影院 | 国产91精品一区二区麻豆网站 | 97超级碰碰碰视频在线观看 | 午夜精品久久 | 麻豆91在线看| 免费碰碰 | 国产一区精品在线观看 | 九九热精品视频在线播放 | 精品国内自产拍在线观看视频 | 亚洲精品午夜视频 | 在线观看日本高清mv视频 | 99re在线视频观看 | 亚洲 综合 国产 精品 | 97影视 | 激情婷婷丁香 | 精品视频免费在线 | 99热在线精品观看 | 免费av小说 | 天天躁日日躁狠狠躁av麻豆 | 久久久久久久久久久久久国产精品 | 永久免费毛片在线观看 | 亚洲自拍偷拍色图 | 69成人在线| 欧美激情精品一区 | 国产中文字幕第一页 | 久久激情五月婷婷 | 玖玖玖国产精品 | 久久天堂精品视频 | 成人久久久久久久久久 | www视频在线播放 | 在线黄色观看 | 亚洲免费视频观看 | 精品国产乱码一区二 | 99久久日韩精品视频免费在线观看 | 国产精品一区二区精品视频免费看 | 东方av在| 日韩欧美高清一区二区 | 狠狠色狠狠色 | 一区二区三区免费播放 | 黄色片视频免费 | 午夜精品久久久久久久99 | 黄色成品视频 | 日韩草比| 国产一级做a | 蜜桃av综合网| 最近2019年日本中文免费字幕 | 免费日韩av片 | 五月开心六月婷婷 | 国产精品入口66mio女同 | 久草91视频 | 在线视频1卡二卡三卡 | 五月综合在线观看 | 国产综合福利在线 | 日韩高清av在线 | 日韩av高清 | 欧美视频国产视频 | 亚洲视频每日更新 | 久草在线观看视频免费 | 天天躁天天操 | 国产精品久久久久久久久毛片 | 亚洲国产字幕 | 一级一片免费看 | 成人亚洲综合 | 玖玖玖精品| 在线观看视频黄色 | 一区二区视频欧美 | 中文永久字幕 | 国产精品久久99精品毛片三a | 国产人成看黄久久久久久久久 | 一级黄色大片在线观看 | 天天天天天操 | 亚洲日本精品 | 色国产在线 | 日日日日日| 日日干干夜夜 | 国产99精品在线观看 | 欧美成人aa | 欧美aaa一级 | 又黄又爽的免费高潮视频 | 波多野结衣小视频 | 91av大全| 天天操天| 岛国av在线| 国产精品一区二区三区免费视频 | 一区二区电影在线观看 | 免费午夜视频在线观看 | 日韩免费播放 | av成人在线播放 | 日韩免费一二三区 | 精品免费观看视频 | 精品久久久久久亚洲综合网 | 91久久电影 | 久99久中文字幕在线 | 亚洲日韩欧美一区二区在线 | 93久久精品日日躁夜夜躁欧美 | a黄色片在线观看 | 国产玖玖精品视频 | 手机看片中文字幕 | 免费av试看 | av成人动漫 | 精品电影一区 | 免费看一级 | 波多野结衣在线中文字幕 | 一区二区三区日韩视频在线观看 | 国产精品欧美久久久久无广告 | 国产综合片 | 人人爱人人舔 | 亚洲精品国精品久久99热一 | 黄网站app在线观看免费视频 | 久久精品久久久久电影 | 亚洲精品在 | 国产91学生粉嫩喷水 | av大全免费在线观看 | 最近乱久中文字幕 | 欧美日韩中文在线观看 | 国产精品区免费视频 | 久久人人爽人人爽人人 | av色图天堂网 | 欧美日韩精品在线一区二区 | 久久婷婷一区二区三区 | 久久免费黄色大片 | 亚洲午夜av电影 | 色婷婷国产 | 97超碰超碰久久福利超碰 | 米奇狠狠狠888 | 免费国产视频 | 免费国产在线精品 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 免费v片 | 伊人天堂av | av一级免费 | 99在线高清视频在线播放 | 91福利在线导航 | 国产大陆亚洲精品国产 | 亚洲高清在线 | 99国产精品免费网站 | 黄色字幕网 | 色橹橹欧美在线观看视频高清 | 色全色在线资源网 | 日韩av高清在线观看 | 91免费版成人 | 国产成人免费av电影 | 中文字幕av免费 | 久久视频这里有精品 | 亚洲精品影视在线观看 | 亚洲精品久久激情国产片 | 久久久精品国产免费观看一区二区 | 视频在线观看国产 | 黄色免费在线看 | 在线观看色网站 | 久久亚洲精品国产亚洲老地址 | 亚洲精品国产拍在线 | 久久久久成人精品免费播放动漫 | 国产一级视频在线观看 | 久久这里只有精品1 | 西西www444| 国产高清av免费在线观看 | 日韩欧美高清视频在线观看 | 成人a在线观看高清电影 | 日韩一级理论片 | 久一在线 | 9ⅰ精品久久久久久久久中文字幕 | 久久久精品免费看 | www.天天干| 色综合天天综合在线视频 | 中文 一区二区 | 91av蜜桃| 国产黄色在线看 | 久久女同性恋中文字幕 | 日韩av高清| 黄色av网站在线免费观看 | 精品国产视频在线 | 日韩久久精品一区二区 | 天天干天天操天天干 | 亚洲最新在线视频 | 五月婷婷激情 | 91九色蝌蚪国产 | 免费观看v片在线观看 | 不卡的av| 亚洲精品在线视频 | 国产精品国内免费一区二区三区 | 在线性视频日韩欧美 | 日本在线精品视频 | 久久久久久久久久久久电影 | 亚洲精品一区中文字幕乱码 | 美女网站色在线观看 | 中文字幕在线观看免费 | 成人精品99 | 精品国产理论 | 久久综合免费视频 | 久久精品牌麻豆国产大山 | 开心综合网 | 91网在线看 | 亚洲综合成人专区片 | 国产中文字幕视频在线观看 | 最近免费观看的电影完整版 | 久草在 | 91精品国自产在线 | 日韩免费电影在线观看 | 久久久久久蜜桃一区二区 | 国产精品第2页 | 丝袜美女视频网站 | 亚洲精品美女在线 | 91九色性视频 | 黄色一级在线免费观看 | 日韩免费在线观看视频 | 欧美肥妇free | 天天搞天天 | 国产视频 久久久 | 人人干天天射 | 又爽又黄又刺激的视频 | 国产高清日韩欧美 | 国产一级免费在线 | 久久草在线视频国产 | 久久综合色一综合色88 | 手机色在线 | 色视频网站在线观看一=区 a视频免费在线观看 | 最近中文字幕免费av | 黄色国产高清 | 天天操天天添 | 一区二区三区四区久久 | 欧美一区二区视频97 | 免费观看视频黄 | 国产午夜精品av一区二区 | 在线观看香蕉视频 | 中文字幕在线久一本久 | 中文字幕人成不卡一区 | 成人黄色免费在线观看 | 久久精品久久久精品美女 | 色www永久免费 | 一本大道久久精品懂色aⅴ 五月婷社区 | 欧美精品亚洲精品日韩精品 | 国产精品自在线拍国产 | 久免费视频 | 日韩亚洲在线观看 | 夜夜爽www| 偷拍视频一区 | 久久精品国亚洲 | 久草在线高清 | 久久久久久久久久久网 | 日韩精品视频在线观看免费 | 色婷婷激情电影 | 久久精品4 | 超碰97在线资源站 | 99视频在线精品国自产拍免费观看 | 久久99国产精品自在自在app | 欧美激情精品久久久久久免费印度 | 伊人久久影视 | av在线电影网站 | 亚洲黄色av | 成人亚洲网 | 成人免费视频播放 | av高清在线观看 | 黄色在线观看网站 | 色狠狠综合 | 色午夜影院 | 国产一卡二卡在线 | 久久精品草 | 久久久久久久久久亚洲精品 | 国产精品女主播一区二区三区 | 国产亚州精品视频 | 日本色小说视频 | 超碰在线公开免费 | 欧美肥妇free | 免费在线观看一区 | 亚洲理论在线观看 | 免费亚洲精品视频 | 国产糖心vlog在线观看 | 91亚洲国产成人久久精品网站 | 在线观看午夜av | 波多野结衣亚洲一区二区 | 天天天射 | 国产精品毛片一区二区在线 | av网站免费线看精品 | 在线香蕉视频 | www.天天射 | 国产精品18久久久久久久网站 | 婷婷成人亚洲综合国产xv88 | 丰满少妇对白在线偷拍 | 精品国产免费一区二区三区五区 | 日韩视频中文字幕在线观看 | 精品色综合 | 日韩精品短视频 | 国产美女主播精品一区二区三区 | 日韩一区二区三区高清免费看看 | 丝袜美女视频网站 | 欧美性色黄 | 日韩精品久久久久久久电影99爱 | 激情网站免费观看 | 超碰97在线看 | 午夜性生活 | 在线观看视频国产一区 | 日韩激情在线 | 91污视频在线观看 | 最新日韩视频 | 丁香视频全集免费观看 | 欧美性生活久久 | 亚洲人成人在线 | 久久免费99精品久久久久久 | 超级碰视频 | 国产裸体永久免费视频网站 | 日韩视频www | 国产在线观看h | 国产成人精品女人久久久 | 天天操人人干 | 亚洲精品视频免费在线 | 美女精品 | 97电影手机版 | 最近中文字幕mv免费高清在线 | 成人免费中文字幕 | 色婷婷88av视频一二三区 | 性色av免费观看 | 日韩毛片在线播放 | 极品国产91在线网站 | 国产精品久久久久久久久久ktv | 中文字幕在线日亚洲9 | 在线观看av麻豆 | 一区二区三区高清不卡 | 天天干夜夜擦 | 黄在线 | 在线观看的av | 日本中文字幕在线视频 | 国产最新视频在线 | 免费福利在线播放 | 亚洲欧美国产视频 | 亚洲综合婷婷 | 依人成人综合网 | 黄色在线网站噜噜噜 | 国产精品9999久久久久仙踪林 | 午夜久久久精品 | 国产精品久久婷婷六月丁香 | 亚洲精品乱码久久久久久蜜桃欧美 | 国产精品白虎 | 热久久这里只有精品 | 国产免费观看av | 日本一区二区高清不卡 | 亚洲精品日韩在线观看 | 91av片| 色婷婷色 | 色综合婷婷| 亚洲春色综合另类校园电影 | 91热| 免费在线观看av网站 | 久久综合狠狠综合久久激情 | 天天视频色版 | 欧美日韩国产精品一区 | 一区二区三区四区在线 | 午夜丁香视频在线观看 | 免费看91的网站 | 日产av在线播放 | 很黄很色很污的网站 | 99精品视频网站 | 精品人人爽 | 精品国产乱码一区二 | 国产色网 | 911国产 | 91视频午夜 | 久久精品艹 | 精品国产色 | 91资源在线| 69人人| 麻豆传媒在线视频 | 欧美激情h | 黄色的网站免费看 | 在线免费观看国产视频 | 91精品久久久久久久久 | 精品国产一区二区三区久久久久久 | 国产一级视频在线免费观看 | 久久久国产视频 | 伊人天堂网 | 麻豆久久一区 | 免费看av在线 | 欧美综合色 | 国产视频2 | 最近更新的中文字幕 | 欧美色图一区 | 五月婷婷婷婷婷 | 99热亚洲精品 | 亚洲午夜精 | 欧美日韩在线观看不卡 | 国产日韩精品一区二区在线观看播放 | 国产黄色精品视频 | 久草在线资源网 | 国产精品一区二区三区四 | 中文字幕在线观看免费高清完整版 | 午夜精品久久久久久久99无限制 | 日韩精品一区二区三区三炮视频 | 天天操天天操天天操天天操 | 99理论片 | 九七视频在线观看 | 久久夜色网 | 最近日韩免费视频 | 国内99视频 | 国产九九九视频 | 天天爽天天爽 | 精品亚洲在线 | 精品黄色视 | 中文字幕在线看视频国产 | 99这里只有精品视频 | 欧美精品999 | 久久精品成人 | 91九色porny在线 | 香蕉视频免费看 | 99久久精品无码一区二区毛片 | 国产精品美女久久久久久久网站 | 天天碰天天操视频 | 日韩有码中文字幕在线 | 九九九九九九精品任你躁 | 久久情爱| 丁香激情视频 | 天天干天天做天天爱 | 亚洲一区二区视频在线播放 | 五月天天在线 | 国产亚洲小视频 | 欧美在线一二 | 亚洲视频1区2区 | 国产精品网址在线观看 | 9999亚洲 | 亚洲jizzjizz日本少妇 | 色的网站在线观看 | 91免费观看 | 伊人手机在线 | 国模视频一区二区三区 | 亚洲国产精品电影 | 日本婷婷色| 在线免费黄网站 | 91九色视频导航 | 日韩在线网址 | 97超碰在线播放 | 久久免费视频这里只有精品 | 99久久精品久久久久久动态片 | 精品国产免费人成在线观看 | 国产成人一区二区三区在线观看 | 精品一区二区影视 | 五月天久久综合 | 亚洲日本va午夜在线影院 | 成人性生交视频 | 日韩精品一区二区三区在线播放 | 日韩视频1| 全久久久久久久久久久电影 | 九九免费观看全部免费视频 | 日韩av免费观看网站 | 免费视频网 | 激情视频91 | 在线成人观看 | 91久久久国产精品 | 天天插天天爽 | 午夜av影院 | 精品亚洲男同gayvideo网站 | 日本精品小视频 | 日韩久久精品一区二区 | 精品国产一区二区三区男人吃奶 | 久久久国产视频 | 国产精品久久一区二区三区不卡 | 亚洲欧美观看 | 黄色中文字幕在线 | 免费在线观看成人 | 国产在线观看二区 | 国产精品午夜久久 | 亚洲永久国产精品 | 草在线视频 | 九九亚洲视频 | 国产日韩精品欧美 | 婷婷在线色 | 国产精品二区在线 | 久久这里 | 久草综合在线观看 | 国产精品一区二区三区观看 | 久久人人插 | 亚洲精品一区二区三区新线路 | 欧美午夜理伦三级在线观看 | 日韩中文字 | 五月婷丁香 | 国产一区免费在线 | 国产一区二区在线影院 | 黄污网站在线 | 久久视频在线免费观看 | 久久99精品久久久久久 | 极品久久久久久久 | 午夜精品久久久久99热app | 久久9999久久免费精品国产 | 国产一区高清在线 | 久久国产影视 | 青青网视频 | 天天射天天舔天天干 | 国产香蕉97碰碰久久人人 | 在线看的毛片 | 天天干天天插 | 99久久精品无免国产免费 | 精品毛片一区二区免费看 | 欧美精品乱码99久久影院 | 中文字幕在线人 | 天天色天天综合网 | a视频在线看| 国产精品免费久久 | 激情综合中文娱乐网 | 久久国产片| 午夜色婷婷| av免费观看网站 | 国产婷婷在线观看 | 日韩免费观看一区二区三区 | 亚洲国产精品电影 | 午夜精品一区二区三区可下载 | 免费在线观看av网站 | 美女视频永久黄网站免费观看国产 | 日韩系列 | 国产日韩在线观看一区 | 色婷婷av一区 | 欧美激情视频一区二区三区 | a特级毛片 | 成人黄视频 | 不卡日韩av | 人人澡人人添人人爽一区二区 | 午夜视频在线网站 | 国产高清不卡一区二区三区 | 国产精品一级在线 | 国产成视频在线观看 | 国产高清永久免费 | 国产午夜精品一区二区三区 | 香蕉视频在线免费 | 国产精品美女在线观看 | 亚洲成av人影片在线观看 | 日韩网站一区二区 | 97精品国自产拍在线观看 | 久久国产精品视频 | av电影亚洲 | 成年人免费看片网站 | 四虎在线观看 | 美女网站视频免费都是黄 | 粉嫩av一区二区三区四区五区 | 狠狠做深爱婷婷综合一区 | 午夜av一区二区三区 | 91麻豆国产 | 日日噜噜噜噜夜夜爽亚洲精品 | 久久一区二区三区日韩 | 在线视频一区观看 | 日本视频精品 | 91精品国产综合久久福利不卡 | 国内精品久久久久久久久久 | 日韩欧美电影在线 | 97超碰在线久草超碰在线观看 | 人人看人人做人人澡 | 五月天激情视频 | 亚洲最新精品 | 一区 二区电影免费在线观看 | 成人中文字幕av | 午夜久久久久久久久久影院 | 黄网站大全 | 91香蕉视频色版 | 九色自拍视频 | 久久99久久99精品免观看粉嫩 | av在线观 | 久久国产欧美日韩精品 | 日韩av伦理片 | 91在线免费视频 | 亚洲国产精品一区二区久久,亚洲午夜 | 美女一区网站 | 国产黄网站在线观看 | 国产一线二线三线性视频 | 午夜性生活 | 国产精品第一页在线 | 国产精品久久二区 | 婷婷丁香国产 | 天天操天天摸天天射 | 少妇性xxx | 99九九热只有国产精品 | 日本中文一区二区 | 色综合天天射 | 国产精品美女在线 | 日韩欧美视频免费在线观看 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 中文字幕成人在线观看 | 福利网址在线观看 | 新版资源中文在线观看 | av色一区 | 99亚洲视频 | 深爱五月网 | 91色一区二区三区 | avove黑丝| 日韩最新理论电影 | 日本久久久久久久久久久 | www.夜色321.com | 午夜精品电影 | 有码视频在线观看 | 日韩理论电影网 | 国产黄色片免费在线观看 | 久久五月情影视 | 又黄又爽的视频在线观看网站 | 在线观看视频一区二区三区 | 午夜私人影院久久久久 | 色综合久久精品 | 天天干天天做 | 日韩r级电影在线观看 | 五月婷婷激情五月 | 高清视频一区二区三区 | 亚州天堂| 狠狠色综合网站久久久久久久 | 日韩毛片一区 | 插婷婷 | 国产做aⅴ在线视频播放 | 久久国产精品99久久久久久进口 | 又污又黄的网站 | 久久久久久久久久久福利 | 亚洲小视频在线观看 | 亚洲干 | 天天色天天色天天色 | 国产原创在线视频 | 国产精品久久嫩一区二区免费 | 九九热久久久 | 成人在线免费视频观看 | 婷婷伊人综合亚洲综合网 | 69亚洲乱 | 日韩精品免费在线观看 | 亚洲综合色丁香婷婷六月图片 | 国产精品v欧美精品v日韩 | 一级黄色片在线免费观看 | 国产小视频你懂的 | 欧美激情第八页 | 日本不卡一区二区三区在线观看 | 香蕉网站在线观看 |