Lua與LuaJit的主要區(qū)別在于LuaJIT是基于JIT(Just-In-Time)技術開發(fā)的,可以實現(xiàn)動態(tài)編譯和執(zhí)行代碼,從而提高了程序的運行效率。而Lua是基于解釋器技術開發(fā)的,不能像LuaJIT那樣進行代碼的即時編譯和執(zhí)行。因此,在運行速度方面,LuaJIT要比Lua快得多。此外,LuaJIT還支持更多的操作系統(tǒng)和處理器架構,具有更廣泛的適用性。但是,由于它引入了JIT技術,其實現(xiàn)復雜度更高,而且在一些特殊情況下,可能會存在性能問題。
這里選擇LuaJit在嵌入式Linux系統(tǒng)使用,LuaJit交叉編譯也比較簡單,沒有第三方庫的依賴,直接交叉編譯源碼即可。
LuaJit移植-交叉編譯
源碼下載
LuaJit的官網(wǎng):https://luajit.org/ ,發(fā)現(xiàn)官網(wǎng)上的鏈接好像下載不下來了,我把我這邊用的源碼上傳到了碼云,可以從這里下載:https://gitee.com/fensnote/demo_code/blob/master/opensource/luajit/LuaJIT-2.0.5.tar.gz。
有個LuaJit開發(fā)文檔博客做的不錯,可以參考下:?luajit開發(fā)文檔中文版https://www.cnblogs.com/zx-admin/p/16363426.html
交叉編譯
源碼下載后,解壓:
tar?xvzf?LuaJit-2.0.5.tar.gz
上面那個博客中有詳細的安裝編譯說明,這里主要引用了其ARM交叉編譯的部分:
基于 GNU Makefile 的構建系統(tǒng)允許在任何主機上為任何受支持的目標進行交叉編譯,只要兩種架構具有相同的指針大小。如果您想在 x64 操作系統(tǒng)上交叉編譯到任何 32 位目標,您需要安裝 multilib 開發(fā)包(例如 Debian/Ubuntu 上的 libc6-dev-i386)并構建 32 位主機部分(HOST_CC="gcc - m32" )。
每當主機操作系統(tǒng)和目標操作系統(tǒng)不同時,您都需要指定TARGET_SYS,否則會出現(xiàn)匯編程序或鏈接器錯誤。例如,如果您在 Windows 或 macOS 主機上為嵌入式 Linux 或 Android 進行編譯,則需要將TARGET_SYS=Linux添加到下面的示例中。對于最小的目標操作系統(tǒng),您可能需要禁用src/Makefile中的內(nèi)置分配器 并使用TARGET_SYS=Other。不要忘記為安裝步驟指定相同的TARGET_SYS。
#?Cross-compile?to?a?32?bit?binary?on?a?multilib?x64?OS
make?CC="gcc?-m32"
#?Cross-compile?on?Debian/Ubuntu?for?Windows?(mingw32?package)
make?HOST_CC="gcc?-m32"?CROSS=i586-mingw32msvc-?TARGET_SYS=Windows
CROSS前綴允許指定標準?的GNU 交叉編譯工具鏈(Binutils、GCC 和匹配的 libc)。前綴可能會因構建工具鏈?的--target不同而有所不同(注意CROSS前綴后面有一個"-")。下面的示例使用適用于 Linux 的規(guī)范工具鏈三元組。
由于在運行時通常沒有簡單的方法來檢測 CPU 功能,因此使用正確的 CPU 或架構設置進行編譯非常重要。您可以在自己構建工具鏈時指定這些。或將?-mcpu=...或-march=...添加到TARGET_CFLAGS。對于 ARM,擁有正確的-mfloat-abi=...設置也很重要。否則 LuaJIT 可能無法以目標 CPU 的全部性能運行。
#?ARM?soft-float
make?HOST_CC="gcc?-m32"?CROSS=arm-linux-gnueabi-?
?????TARGET_CFLAGS="-mfloat-abi=soft"
#?ARM?soft-float?ABI?with?VFP?(example?for?Cortex-A8)
make?HOST_CC="gcc?-m32"?CROSS=arm-linux-gnueabi-?
?????TARGET_CFLAGS="-mcpu=cortex-a8?-mfloat-abi=softfp"
#?ARM?hard-float?ABI?with?VFP?(armhf,?requires?recent?toolchain)
make?HOST_CC="gcc?-m32"?CROSS=arm-linux-gnueabihf-
#?PPC
make?HOST_CC="gcc?-m32"?CROSS=powerpc-linux-gnu-
#?PPC/e500v2?(fast?interpreter?only)
make?HOST_CC="gcc?-m32"?CROSS=powerpc-e500v2-linux-gnuspe-
#?MIPS?big-endian
make?HOST_CC="gcc?-m32"?CROSS=mips-linux-
#?MIPS?little-endian
make?HOST_CC="gcc?-m32"?CROSS=mipsel-linux-
編譯還是挺順利的,我這邊編譯了兩種處理器的版本,沒有出現(xiàn)什么錯誤。編譯好之后,可以修改Makefile里的安裝目錄:
Makefile
修改為指定的安裝目錄,然后執(zhí)行安裝命令:make install 安裝目錄下的文件結構:
編譯結果
我們只需要把bin、lib下載到板子里,我這邊是放在了/usr/local/下面。這時就以執(zhí)行l(wèi)uajit命令來測試下:
$luajit
LuaJIT?2.0.5?--?Copyright?(C)?2005-2017?Mike?Pall.?http://luajit.org/
JIT:?ON?CMOV?SSE2?SSE3?SSE4.1?fold?cse?dce?fwd?dse?narrow?loop?abc?sink?fuse
>?print("hello?luajit!")
hello?luajit!
>
然后我們在編譯個json的擴展庫,json在實際開發(fā)中用的比較多,這里可以下載一個lua-cjson庫進行交叉編譯一下,源文件也在上面的碼云鏈接里下載。
解壓編譯,cjson編譯也比較簡單,只需要改下編譯器,修改一下lua頭文件的路徑,頭文件路徑即剛才安裝LuaJit時的目錄里的include。修改如下:
Makefile修改
然后編譯即可:
make?CC=arm-none-linux-gcc?
arm-none-linux-gcc?-c?-O3?-Wall?-pedantic?-DNDEBUG??-I../install/include/luajit-2.0/?-fpic?-o?lua_cjson.o?lua_cjson.c
arm-none-linux-gcc?-c?-O3?-Wall?-pedantic?-DNDEBUG??-I../install/include/luajit-2.0/?-fpic?-o?strbuf.o?strbuf.c
arm-none-linux-gcc?-c?-O3?-Wall?-pedantic?-DNDEBUG??-I../install/include/luajit-2.0/?-fpic?-o?fpconv.o?fpconv.c
arm-none-linux-gcc??-shared?-o?cjson.so?lua_cjson.o?strbuf.o?fpconv.o
文件比較少,編譯完成后生成cjson.so,這個和平時Linux的動態(tài)庫名字規(guī)則不太一樣,前面不用“l(fā)ib”開頭。
然后這個cjson.so下載到: /usr/local/lib/lua/5.1 這樣就完成了。
測試
測試下json的使用:
local?cjson?=?require("cjson")
local?json_str?=?'{"name":"John",?"age":30,?"city":"鄭州"}'
local?json_tab?=?cjson.decode(json_str)
print(json_tab.name)??--?輸出?"John"
print(json_tab.age)???--?輸出?30
print(json_tab.city)??--?輸出?"New?York"
運行:
luajit?test_cjson.lua
輸出:
John
30
鄭州
另外使用lua的table可以很方便的與json互轉。
引用鏈接
[1]
?luajit開發(fā)文檔中文版(二)LuaJIT擴展 - zh7314 - 博客園:?https://www.cnblogs.com/zx-admin/p/16363431.html