编辑:佚名 2021-06-08 17:23:34 来源于:魔法系统之家下载
启动 Android Studio ,创建一个 Android 项目,勾选 C++ Support。
一路 Next 到这里,直接 Finish,不用勾选保持默认即可。
如果之前没有安装 NDK 和 Cmake 工具,到这里会提示安装 NDK 等工具,直接安装,我这里之前已经安装了,所以略过。
等待工程就绪之后,正常构建一次,看 Hello World 能不能正常构建运行起来。查看编译后的 APK 文件,看看里面是否有下列目录和 .so 文件。
Executing tasks: [:app:assembleDebug] 省略一堆Log External native generate JSON debug: JSON generation completed without problems :app:externalNativeBuildDebug Build native-lib x86_64 [1/2] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/native-lib.cpp.o [2/2] Linking CXX shared library ..\..\..\..\build\intermediates\cmake\debug\obj\x86_64\libnative-lib.so Build native-lib x86 [1/2] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/native-lib.cpp.o [2/2] Linking CXX shared library ..\..\..\..\build\intermediates\cmake\debug\obj\x86\libnative-lib.so Build native-lib arm64-v8a [1/2] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/native-lib.cpp.o [2/2] Linking CXX shared library ..\..\..\..\build\intermediates\cmake\debug\obj\arm64-v8a\libnative-lib.so Build native-lib armeabi-v7a [1/2] Building CXX object CMakeFiles/native-lib.dir/src/main/cpp/native-lib.cpp.o [2/2] Linking CXX shared library ..\..\..\..\build\intermediates\cmake\debug\obj\armeabi-v7a\libnative-lib.so :app:compileDebugSources :app:mergeDebugShaders :app:compileDebugShaders :app:generateDebugAssets :app:mergeDebugAssets :app:transformClassesWithDexBuilderForDebug :app:transformDexArchiveWithExternalLibsDexMergerForDebug :app:transformDexArchiveWithDexMergerForDebug :app:mergeDebugJniLibFolders :app:transformNativeLibsWithMergeJniLibsForDebug :app:transformNativeLibsWithStripDebugSymbolForDebug :app:processDebugJavaRes NO-SOURCE :app:transformResourcesWithMergeJavaResForDebug :app:validateSigningDebug :app:packageDebug :app:assembleDebugBUILD SUCCESSFUL in 12s 29 actionable tasks: 16 executed, 13 up-to-date
通过 7-Zip 可以查看 APK 里面的文件组成结构,如下是 lib 目录下的内容,分别对应不同的 CPU 架构。
如果能到这一步,说明至少 Android Studio 配置基本是 OK 的,NDK 能正常工作。
在 Android Studio 3.1 后,Gradle Console 就不见了,要查看构建过程和步骤,在 Build 窗口点击 Toggle View 就可以查看构建步骤了。
在 Project 面板中,CPP 目录下的文件就是 C/CPP 的源文件目录,我们从 Lua 官网下载源码后,将 .c 和 .h 文件当道这个目录下面。
目前我能下载到最新的 Lua 版本是 5.3.5 ,粘贴到 CPP 目录后,文件并不会显示,不知道这是不是 Android Studio 的 bug,接下来修改 CMakeLists.txt 里面的内容,将源代码增加到构建列表。
add_library( # Sets the name of the library. luajit# Sets the library as a shared library. SHARED# Provides a relative path to your source file(s). src/main/cpp/lapi.c src/main/cpp/lauxlib.c src/main/cpp/lbaselib.c src/main/cpp/lbitlib.c src/main/cpp/lcode.c src/main/cpp/lcorolib.c src/main/cpp/lctype.c src/main/cpp/ldblib.c src/main/cpp/ldebug.c src/main/cpp/ldo.c src/main/cpp/ldump.c src/main/cpp/lfunc.c src/main/cpp/lgc.c src/main/cpp/linit.c src/main/cpp/liolib.c src/main/cpp/llex.c src/main/cpp/lmathlib.c src/main/cpp/lmem.c src/main/cpp/loadlib.c src/main/cpp/lobject.c src/main/cpp/lopcodes.c src/main/cpp/loslib.c src/main/cpp/lparser.c src/main/cpp/lstate.c src/main/cpp/lstate.h src/main/cpp/lstring.c src/main/cpp/lstrlib.c src/main/cpp/ltable.c src/main/cpp/ltablib.c src/main/cpp/ltm.c src/main/cpp/lua.c src/main/cpp/lua.hpp src/main/cpp/lundump.c src/main/cpp/lutf8lib.c src/main/cpp/lvm.c src/main/cpp/lzio.c)
执行编译,这个时候 Build 窗口可能会出现一片红 …
具体错误内容如下:
Execution failed for task ‘:app:externalNativeBuildDebug’. > Build command failed. Error while executing process D:\ANDROID\Sdk\cmake\3.6.4111459\bin\cmake.exe with arguments {–build D:\ANDROID_PROJECTS\HelloLua2\app\.externalNativeBuild\cmake\debug\x86_64 –target luajit} [1/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o [2/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o [3/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o [4/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o [5/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o [6/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o [7/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o [8/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o [9/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o [10/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o [11/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o [12/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o [13/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o [14/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o [15/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/linit.c.o [16/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o [17/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/llex.c.o [18/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o [19/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o [20/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o [21/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o [22/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o [23/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o [24/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o [25/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o [26/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o [27/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lua.c.o [28/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/luac.c.o [29/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o [30/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o [31/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o [32/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o [33/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o [34/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o [35/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o D:\ANDROID_PROJECTS\HelloLua2\app\src\main\cpp\loslib.c:169:3: warning: ‘tmpnam’ is deprecated: tempnam is unsafe, use mkstemp or tmpfile instead [-Wdeprecated-declarations] lua_tmpnam(buff, err); ^ D:\ANDROID_PROJECTS\HelloLua2\app\src\main\cpp\loslib.c:131:33: note: expanded from macro ‘lua_tmpnam’ #define lua_tmpnam(b,e) { e = (tmpnam(b) == NULL); } ^ D:/ANDROID/Sdk/ndk-bundle/sysroot/usr/include\stdio.h:167:5: note: ‘tmpnam’ has been explicitly marked deprecated here __warnattr(“tempnam is unsafe, use mkstemp or tmpfile instead”); ^ D:/ANDROID/Sdk/ndk-bundle/sysroot/usr/include\sys/cdefs.h:160:40: note: expanded from macro ‘__warnattr’ #define __warnattr(msg) __attribute__((deprecated(msg))) ^ 1 warning generated. [36/36] Linking C shared library ..\..\..\..\build\intermediates\cmake\debug\obj\x86_64\libluajit.so FAILED: cmd.exe /C “cd . && D:\ANDROID\Sdk\ndk-bundle\toolchains\llvm\prebuilt\windows-x86_64\bin\clang.exe –target=x86_64-none-linux-android21 –gcc-toolchain=D:/ANDROID/Sdk/ndk-bundle/toolchains/x86_64-4.9/prebuilt/windows-x86_64 –sysroot=D:/ANDROID/Sdk/ndk-bundle/sysroot -fPIC -isystem D:/ANDROID/Sdk/ndk-bundle/sysroot/usr/include/x86_64-linux-android -g -DANDROID -ffunction-sections -funwind-tables -fstack-protector-strong -no-canonical-prefixes -Wa,–noexecstack -Wformat -Werror=format-security -O0 -fno-limit-debug-info -Wl,–exclude-libs,libgcc.a -Wl,–exclude-libs,libatomic.a -nostdlib++ –sysroot D:/ANDROID/Sdk/ndk-bundle/platforms/android-21/arch-x86_64 -Wl,–build-id -Wl,–warn-shared-textrel -Wl,–fatal-warnings -LD:/ANDROID/Sdk/ndk-bundle/sources/cxx-stl/llvm-libc++/libs/x86_64 -Wl,–no-undefined -Wl,-z,noexecstack -Qunused-arguments -Wl,-z,relro -Wl,-z,now -shared -Wl,-soname,libluajit.so -o ..\..\..\..\build\intermediates\cmake\debug\obj\x86_64\libluajit.so CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o CMakeFiles/luajit.dir/src/main/cpp/linit.c.o CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o CMakeFiles/luajit.dir/src/main/cpp/llex.c.o CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o CMakeFiles/luajit.dir/src/main/cpp/lua.c.o CMakeFiles/luajit.dir/src/main/cpp/luac.c.o CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o -llog -latomic -lm && cd .” D:/ANDROID/Sdk/ndk-bundle/toolchains/x86_64-4.9/prebuilt/windows-x86_64/lib/gcc/x86_64-linux-android/4.9.x/../../../../x86_64-linux-android/bin\ld: error: CMakeFiles/luajit.dir/src/main/cpp/luac.c.o: multiple definition of ‘main’ D:/ANDROID/Sdk/ndk-bundle/toolchains/x86_64-4.9/prebuilt/windows-x86_64/lib/gcc/x86_64-linux-android/4.9.x/../../../../x86_64-linux-android/bin\ld: CMakeFiles/luajit.dir/src/main/cpp/lua.c.o: previous definition here clang.exe: error: linker command failed with exit code 1 (use -v to see invocation) ninja: build stopped: subcommand failed.* Try: Run with –stacktrace option to get the stack trace. Run with –info or –debug option to get more log output. Run with –scan to get full insights.* Get more help at https://help.gradle.orgBUILD FAILED in 9s 21 actionable tasks: 18 executed, 3 up-to-date
提示中说的也比较清楚,我们使用了已经废弃了的函数:warning: ‘tmpnam’ is deprecated: tempnam is unsafe, use mkstemp or tmpfile instead,但是项目中,使用这个 tmpnam 的比较多,而且需要改 Lua 源代码,本着不对 Lua 改动的原则,我们在 CMakeLists.txt 中增加下面的一行代码,屏蔽废弃函数的错误警告。
add_definitions(-Wno-deprecated)
最终,文件结构如下:
继续编译,发现依然编译不通过,Build 窗口依然一片红,如下:
Executing tasks: [clean, :app:assembleDebug] 省略一堆Log * What went wrong: Execution failed for task ‘:app:externalNativeBuildDebug’. > Build command failed. Error while executing process D:\ANDROID\Sdk\cmake\3.6.4111459\bin\cmake.exe with arguments {–build D:\ANDROID_PROJECTS\HelloLua2\app\.externalNativeBuild\cmake\debug\x86_64 –target luajit} Recompacting log… [1/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o [2/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o [3/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o [4/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o [5/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o [6/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o [7/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o [8/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o [9/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/linit.c.o [10/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o [11/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o [12/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o [13/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/llex.c.o [14/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o [15/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o [16/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o [17/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o [18/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o [19/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o [20/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o [21/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o [22/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o [23/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o [24/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o [25/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lua.c.o [26/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o [27/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o [28/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o [29/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o [30/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o [31/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o [32/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o [33/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o [34/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/luac.c.o [35/36] Building C object CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o [36/36] Linking C shared library ..\..\..\..\build\intermediates\cmake\debug\obj\x86_64\libluajit.so FAILED: cmd.exe /C “cd . && D:\ANDROID\Sdk\ndk-bundle\toolchains\llvm\prebuilt\windows-x86_64\bin\clang.exe –target=x86_64-none-linux-android21 –gcc-toolchain=D:/ANDROID/Sdk/ndk-bundle/toolchains/x86_64-4.9/prebuilt/windows-x86_64 –sysroot=D:/ANDROID/Sdk/ndk-bundle/sysroot -fPIC -isystem D:/ANDROID/Sdk/ndk-bundle/sysroot/usr/include/x86_64-linux-android -g -DANDROID -ffunction-sections -funwind-tables -fstack-protector-strong -no-canonical-prefixes -Wa,–noexecstack -Wformat -Werror=format-security -O0 -fno-limit-debug-info -Wl,–exclude-libs,libgcc.a -Wl,–exclude-libs,libatomic.a -nostdlib++ –sysroot D:/ANDROID/Sdk/ndk-bundle/platforms/android-21/arch-x86_64 -Wl,–build-id -Wl,–warn-shared-textrel -Wl,–fatal-warnings -LD:/ANDROID/Sdk/ndk-bundle/sources/cxx-stl/llvm-libc++/libs/x86_64 -Wl,–no-undefined -Wl,-z,noexecstack -Qunused-arguments -Wl,-z,relro -Wl,-z,now -shared -Wl,-soname,libluajit.so -o ..\..\..\..\build\intermediates\cmake\debug\obj\x86_64\libluajit.so CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o CMakeFiles/luajit.dir/src/main/cpp/linit.c.o CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o CMakeFiles/luajit.dir/src/main/cpp/llex.c.o CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o CMakeFiles/luajit.dir/src/main/cpp/lua.c.o CMakeFiles/luajit.dir/src/main/cpp/luac.c.o CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o -llog -latomic -lm && cd .” D:/ANDROID/Sdk/ndk-bundle/toolchains/x86_64-4.9/prebuilt/windows-x86_64/lib/gcc/x86_64-linux-android/4.9.x/../../../../x86_64-linux-android/bin\ld: error: CMakeFiles/luajit.dir/src/main/cpp/luac.c.o: multiple definition of ‘main’ D:/ANDROID/Sdk/ndk-bundle/toolchains/x86_64-4.9/prebuilt/windows-x86_64/lib/gcc/x86_64-linux-android/4.9.x/../../../../x86_64-linux-android/bin\ld: CMakeFiles/luajit.dir/src/main/cpp/lua.c.o: previous definition here clang.exe: error: linker command failed with exit code 1 (use -v to see invocation) ninja: build stopped: subcommand failed.* Try: Run with –stacktrace option to get the stack trace. Run with –info or –debug option to get more log output. Run with –scan to get full insights.* Get more help at https://help.gradle.orgBUILD FAILED in 9s 21 actionable tasks: 19 executed, 2 up-to-date
在这个错误里,有两处非常明显:
error: CMakeFiles/luajit.dir/src/main/cpp/luac.c.o: multiple definition of ‘main’ CMakeFiles/luajit.dir/src/main/cpp/lua.c.o: previous definition here
事实上,我们也不需要 Main 函数的定义,因为编译为 SHARE_LIBRARY ,所以屏蔽这个文件即可。
再次构建,发现还是一片红… 错误如下:
省略一堆Log Execution failed for task ‘:app:externalNativeBuildDebug’. > Build command failed. Error while executing process D:\ANDROID\Sdk\cmake\3.6.4111459\bin\cmake.exe with arguments {–build D:\ANDROID_PROJECTS\HelloLua2\app\.externalNativeBuild\cmake\debug\x86 –target luajit} [1/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o [2/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o [3/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o [4/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o [5/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o [6/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o [7/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o [8/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o [9/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o [10/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o [11/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o [12/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o [13/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/llex.c.o [14/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o [15/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o [16/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o [17/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o [18/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/linit.c.o [19/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o [20/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o [21/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o [22/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o [23/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o [24/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o [25/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o [26/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o [27/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lua.c.o [28/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o [29/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o [30/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o [31/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o [32/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o [33/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o [34/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o [35/35] Linking C shared library ..\..\..\..\build\intermediates\cmake\debug\obj\x86\libluajit.so FAILED: cmd.exe /C “cd . && D:\ANDROID\Sdk\ndk-bundle\toolchains\llvm\prebuilt\windows-x86_64\bin\clang.exe –target=i686-none-linux-android19 –gcc-toolchain=D:/ANDROID/Sdk/ndk-bundle/toolchains/x86-4.9/prebuilt/windows-x86_64 –sysroot=D:/ANDROID/Sdk/ndk-bundle/sysroot -fPIC -isystem D:/ANDROID/Sdk/ndk-bundle/sysroot/usr/include/i686-linux-android -g -DANDROID -ffunction-sections -funwind-tables -fstack-protector-strong -no-canonical-prefixes -mstackrealign -Wa,–noexecstack -Wformat -Werror=format-security -O0 -fno-limit-debug-info -Wl,–exclude-libs,libgcc.a -Wl,–exclude-libs,libatomic.a -nostdlib++ –sysroot D:/ANDROID/Sdk/ndk-bundle/platforms/android-19/arch-x86 -Wl,–build-id -Wl,–warn-shared-textrel -Wl,–fatal-warnings -LD:/ANDROID/Sdk/ndk-bundle/sources/cxx-stl/llvm-libc++/libs/x86 -Wl,–no-undefined -Wl,-z,noexecstack -Qunused-arguments -Wl,-z,relro -Wl,-z,now -shared -Wl,-soname,libluajit.so -o ..\..\..\..\build\intermediates\cmake\debug\obj\x86\libluajit.so CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o CMakeFiles/luajit.dir/src/main/cpp/linit.c.o CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o CMakeFiles/luajit.dir/src/main/cpp/llex.c.o CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o CMakeFiles/luajit.dir/src/main/cpp/lua.c.o CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o -llog -latomic -lm && cd .” D:\ANDROID_PROJECTS\HelloLua2\app\src\main\cpp/liolib.c:446: error: undefined reference to ‘localeconv’ D:\ANDROID_PROJECTS\HelloLua2\app\src\main\cpp/lobject.c:287: error: undefined reference to ‘localeconv’ D:\ANDROID_PROJECTS\HelloLua2\app\src\main\cpp/lobject.c:381: error: undefined reference to ‘localeconv’ D:\ANDROID_PROJECTS\HelloLua2\app\src\main\cpp/lstrlib.c:936: error: undefined reference to ‘localeconv’ clang.exe: error: linker command failed with exit code 1 (use -v to see invocation) ninja: build stopped: subcommand failed.* Try: Run with –stacktrace option to get the stack trace. Run with –info or –debug option to get more log output. Run with –scan to get full insights.* Get more help at https://help.gradle.orgBUILD FAILED in 12s 21 actionable tasks: 18 executed, 3 up-to-date
这次的错误都是这一个:undefined reference to ‘localeconv’,解决办法是提高 API Level ,我们把它改为 21 以上就可以解决这个问题。
再次构建,终于不再报错了,结果如下:
Executing tasks: [clean, :app:assembleDebug] 省略一堆Log :app:externalNativeBuildCleanDebug Clean luajit armeabi-v7a Cleaning… 0 files. Clean luajit arm64-v8a Cleaning… 0 files. Clean luajit x86 Cleaning… 0 files. Clean luajit x86_64 Cleaning… 35 files. :app:externalNativeBuildCleanRelease Clean luajit armeabi-v7a Cleaning… 0 files. Clean luajit arm64-v8a Cleaning… 0 files. Clean luajit x86 Cleaning… 0 files. Clean luajit x86_64 Cleaning… 0 files. :app:clean :app:preBuild UP-TO-DATE :app:preDebugBuild :app:compileDebugAidl :app:compileDebugRenderscript :app:checkDebugManifest :app:generateDebugBuildConfig :app:prepareLintJar UP-TO-DATE :app:mainApkListPersistenceDebug :app:generateDebugResValues :app:generateDebugResources :app:mergeDebugResources :app:createDebugCompatibleScreenManifests :app:processDebugManifest :app:splitsDiscoveryTaskDebug :app:processDebugResources :app:generateDebugSources :app:javaPreCompileDebug :app:compileDebugJavaWithJavac :app:generateJsonModelDebug UP-TO-DATE :app:externalNativeBuildDebug Build luajit x86_64 Recompacting log… [1/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o [2/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o [3/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o [4/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o [5/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o [6/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o [7/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o [8/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o [9/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o [10/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o [11/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o [12/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o [13/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/linit.c.o [14/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o [15/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o [16/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/llex.c.o [17/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o [18/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o [19/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o [20/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o [21/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o [22/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o [23/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o [24/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o [25/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o [26/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o [27/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o [28/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o [29/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o [30/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o [31/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o [32/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o [33/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o [34/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lua.c.o [35/35] Linking C shared library ..\..\..\..\build\intermediates\cmake\debug\obj\x86_64\libluajit.so Build luajit x86 [1/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o [2/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o [3/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o [4/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o [5/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o [6/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o [7/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o [8/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o [9/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o [10/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o [11/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o [12/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o [13/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/llex.c.o [14/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/linit.c.o [15/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o [16/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o [17/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o [18/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o [19/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o [20/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o [21/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o [22/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o [23/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o [24/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o [25/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o [26/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o [27/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o [28/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o [29/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o [30/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o [31/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o [32/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lua.c.o [33/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o [34/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o [35/35] Linking C shared library ..\..\..\..\build\intermediates\cmake\debug\obj\x86\libluajit.so Build luajit arm64-v8a [1/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o [2/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o [3/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o [4/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o [5/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o [6/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o [7/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o [8/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o [9/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/linit.c.o [10/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o [11/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o [12/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o [13/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o [14/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o [15/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o [16/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/llex.c.o [17/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o [18/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o [19/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o [20/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o [21/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o [22/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o [23/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o [24/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o [25/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lua.c.o [26/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o [27/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o [28/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o [29/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o [30/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o [31/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o [32/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o [33/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o [34/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o [35/35] Linking C shared library ..\..\..\..\build\intermediates\cmake\debug\obj\arm64-v8a\libluajit.so Build luajit armeabi-v7a [1/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcorolib.c.o [2/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbitlib.c.o [3/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lapi.c.o [4/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lauxlib.c.o [5/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lbaselib.c.o [6/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lcode.c.o [7/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldo.c.o [8/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/llex.c.o [9/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldump.c.o [10/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lobject.c.o [11/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/liolib.c.o [12/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmathlib.c.o [13/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lmem.c.o [14/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loadlib.c.o [15/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldebug.c.o [16/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lfunc.c.o [17/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ldblib.c.o [18/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lgc.c.o [19/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/linit.c.o [20/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lctype.c.o [21/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lua.c.o [22/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lopcodes.c.o [23/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltm.c.o [24/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/loslib.c.o [25/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lundump.c.o [26/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltable.c.o [27/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstring.c.o [28/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lutf8lib.c.o [29/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lzio.c.o [30/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstate.c.o [31/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lvm.c.o [32/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/ltablib.c.o [33/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lstrlib.c.o [34/35] Building C object CMakeFiles/luajit.dir/src/main/cpp/lparser.c.o [35/35] Linking C shared library ..\..\..\..\build\intermediates\cmake\debug\obj\armeabi-v7a\libluajit.so :app:compileDebugSources :app:mergeDebugShaders :app:compileDebugShaders :app:generateDebugAssets :app:mergeDebugAssets :app:transformClassesWithDexBuilderForDebug :app:transformDexArchiveWithExternalLibsDexMergerForDebug :app:transformDexArchiveWithDexMergerForDebug :app:mergeDebugJniLibFolders :app:transformNativeLibsWithMergeJniLibsForDebug :app:transformNativeLibsWithStripDebugSymbolForDebug :app:processDebugJavaRes NO-SOURCE :app:transformResourcesWithMergeJavaResForDebug :app:validateSigningDebug :app:packageDebug :app:assembleDebugBUILD SUCCESSFUL in 20s 33 actionable tasks: 30 executed, 3 up-to-date
再生成 APK,使用 7-ZIP 查看 APK,就可以看到我们 Lua 已经稳妥妥的在 APK 安装包中了,达到 340 KB了,对于 so 库来说也不小了。
至此,Lua 已经编译好了,如果需要使用,还需要写 JNI 方法调用,不过那是后话了。
Github 地址:https://github.com/yahch/Luandroid