【错误记录】Android NDK 错误排查记录 ( error: undefined reference to | Linking CXX shared library FAILED )
2023-06-13 09:17:42 时间
文章目
一、 报错信息
报错信息 :
Build command failed.
Error while executing process Y:\001_DevelopTools\002_Android_SDK\cmake\3.6.4111459\bin\cmake.exe with arguments {--build Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\.externalNativeBuild\cmake\debug\armeabi-v7a --target native-lib}
[1/9] Building C object librtmp/CMakeFiles/rtmp.dir/parseurl.c.o
[2/9] Building C object librtmp/CMakeFiles/rtmp.dir/amf.c.o
[3/9] Building C object librtmp/CMakeFiles/rtmp.dir/hashswf.c.o
[4/9] Building C object librtmp/CMakeFiles/rtmp.dir/rtmp.c.o
[5/9] Building C object librtmp/CMakeFiles/rtmp.dir/log.c.o
In file included from Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\src\main\cpp\librtmp\amf.c:33:
Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\src\main\cpp\librtmp/bytes.h:74:2: warning: "Float word order not defined, assuming the same as byte order!" [-W#warnings]
#warning "Float word order not defined, assuming the same as byte order!"
^
1 warning generated.
[6/9] Linking C static library librtmp\librtmp.a
[7/9] Building CXX object CMakeFiles/native-lib.dir/VedioChannel.cpp.o
[8/9] Building CXX object CMakeFiles/native-lib.dir/native-lib.cpp.o
clang++: warning: argument unused during compilation: '-LY:/002_WorkSpace/001_AS/RTMP_Pusher/app/src/main/cpp/libs/armeabi-v7a' [-Wunused-command-line-argument]
clang++: warning: argument unused during compilation: '-LY:/002_WorkSpace/001_AS/RTMP_Pusher/app/src/main/cpp/libs/armeabi-v7a' [-Wunused-command-line-argument]
[9/9] Linking CXX shared library Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\build\intermediates\cmake\debug\obj\armeabi-v7a\libnative-lib.so
FAILED: cmd.exe /C "cd . && Y:\001_DevelopTools\002_Android_SDK\ndk-bundle\toolchains\llvm\prebuilt\windows-x86_64\bin\clang++.exe --target=armv7-none-linux-androideabi21 --gcc-toolchain=Y:/001_DevelopTools/002_Android_SDK/ndk-bundle/toolchains/llvm/prebuilt/windows-x86_64 --sysroot=Y:/001_DevelopTools/002_Android_SDK/ndk-bundle/toolchains/llvm/prebuilt/windows-x86_64/sysroot -fPIC -g -DANDROID -fdata-sections -ffunction-sections -funwind-tables -fstack-protector-strong -no-canonical-prefixes -fno-addrsig -march=armv7-a -mthumb -Wa,--noexecstack -Wformat -Werror=format-security -LY:/002_WorkSpace/001_AS/RTMP_Pusher/app/src/main/cpp/libs/armeabi-v7a -O0 -fno-limit-debug-info -Wl,--exclude-libs,libgcc.a -Wl,--exclude-libs,libatomic.a -static-libstdc++ -Wl,--build-id -Wl,--warn-shared-textrel -Wl,--fatal-warnings -Wl,--exclude-libs,libunwind.a -Wl,--no-undefined -Qunused-arguments -Wl,-z,noexecstack -shared -Wl,-soname,libnative-lib.so -o Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\build\intermediates\cmake\debug\obj\armeabi-v7a\libnative-lib.so CMakeFiles/native-lib.dir/native-lib.cpp.o CMakeFiles/native-lib.dir/VedioChannel.cpp.o librtmp/librtmp.a -llog -latomic -lm && cd ."
Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\src\main\cpp/VedioChannel.cpp:23: error: undefined reference to 'x264_picture_clean'
Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\src\main\cpp/VedioChannel.cpp:79: error: undefined reference to 'x264_param_default_preset'
Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\src\main\cpp/VedioChannel.cpp:169: error: undefined reference to 'x264_picture_clean'
Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\src\main\cpp/VedioChannel.cpp:177: error: undefined reference to 'x264_picture_alloc'
Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\src\main\cpp/VedioChannel.cpp:182: error: undefined reference to 'x264_encoder_close'
Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\src\main\cpp/VedioChannel.cpp:186: error: undefined reference to 'x264_encoder_open_157'
Y:\002_WorkSpace\001_AS\RTMP_Pusher\app\src\main\cpp/VedioChannel.cpp:248: error: undefined reference to 'x264_encoder_encode'
clang++: error: linker command failed with exit code 1 (use -v to see invocation)
ninja: build stopped: subcommand failed.
二、 错误分析
CMakeList.txt 构建脚本如下 : 跟着该构建脚本 , 逐步向下排查 ;
cmake_minimum_required(VERSION 3.4.1)
# 链接 src/main/cpp/librtmp 目录下的构建脚本
add_subdirectory(librtmp)
add_library( # 函数库名称
native-lib
# 动态库类型
SHARED
# 源文件
native-lib.cpp
VedioChannel.cpp)
find_library( # 日志库
log-lib
log )
# 设置头文件搜索路径
include_directories(include)
# 通过设置编译选项, 设置函数库的搜索路径
# 此处的 ANDROID_ABI 是在
# build.gradle android->defaultConfig->externalNativeBuild->cmake
# 下的 abiFilters 中设置
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -L${CMAKE_SOURCE_DIR}/libs/${ANDROID_ABI}")
target_link_libraries( # 链接动态库
native-lib
# 编译的 rtmp 静态库
rtmp
${log-lib} )
NDK 代码编译时 , 执行了
个步骤 , 第 1 ~ 6 步骤 :
开始构建时 , 指定第一行编译脚本内容 , add_subdirectory(librtmp) , 编译 librtmp 目录下的 CMakeList.txt 内容 ;
# 链接 src/main/cpp/librtmp 目录下的构建脚本
add_subdirectory(librtmp)
编译 RTMP 源代码 , 该步骤执行下面的构建脚本 , 编译 librtmp.so 库 , 对应了如下脚本内容 ;
cmake_minimum_required(VERSION 3.4.1)
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DNO_CRYPTO")
add_library( # 编译的库的名称是 rtmp
rtmp
# 编译的 rtmp 库是静态库
STATIC
# rtmp 库的源文件
amf.c
hashswf.c
log.c
parseurl.c
rtmp.c )
第
步 , 编译 VedioChannel.cpp 源码 , 编译 native-lib.cpp 源码 , 对应编译 libnative-lib.so 函数库 ;
add_library( # 函数库名称
native-lib
# 动态库类型
SHARED
# 源文件
native-lib.cpp
VedioChannel.cpp)
第
步 , 链接函数库 , 在这一步链接出错 , 没有找到 x264 开源库中的函数 ;
x264 开源库编译过程 : x264 开源库的头文件放在 include 目录中 , 交叉编译的函数库放在 libs/armeabi-v7a 目录中 ;
# 设置头文件搜索路径
include_directories(include)
# 通过设置编译选项, 设置函数库的搜索路径
# 此处的 ANDROID_ABI 是在
# build.gradle android->defaultConfig->externalNativeBuild->cmake
# 下的 abiFilters 中设置
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -L${CMAKE_SOURCE_DIR}/libs/${ANDROID_ABI}")
x264 开源库肯定是编译通过了 , 在链接的时候 , x264 没有链接到 native-lib 中 , 导致无法访问 x264 开源库中的函数 ;
target_link_libraries( # 链接动态库
native-lib
# 编译的 rtmp 静态库
rtmp
${log-lib} )
修改方法 : 在链接库的时候 , 将 x264 库添加上去 ;
target_link_libraries( # 链接动态库
native-lib
# 编译的 rtmp 静态库
rtmp
# 预编译的 x264 静态库
x264
${log-lib} )
最终修改后的构建脚本 ( 正确构建脚本 ) :
cmake_minimum_required(VERSION 3.4.1)
# 链接 src/main/cpp/librtmp 目录下的构建脚本
add_subdirectory(librtmp)
add_library( # 函数库名称
native-lib
# 动态库类型
SHARED
# 源文件
native-lib.cpp
VedioChannel.cpp)
find_library( # 日志库
log-lib
log )
# 设置头文件搜索路径
include_directories(include)
# 通过设置编译选项, 设置函数库的搜索路径
# 此处的 ANDROID_ABI 是在
# build.gradle android->defaultConfig->externalNativeBuild->cmake
# 下的 abiFilters 中设置
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -L${CMAKE_SOURCE_DIR}/libs/${ANDROID_ABI}")
target_link_libraries( # 链接动态库
native-lib
# 编译的 rtmp 静态库
rtmp
# 预编译的 x264 静态库
x264
${log-lib} )
三、 错误总结
错误总结 : 遇到 Linking CXX shared library 步骤失败 , 并提示 error: undefined reference to 无法找到函数 , 是链接步骤出错 , 修改 CMakeList.txt 中的 target_link_libraries 链接参数 ;
相关文章
- 聚焦 Android 11: 大功告成
- android scaleanimation动画,【Android动画九章】-RotateAnimation(旋转动画)和ScaleAnimation(尺寸动画)…[通俗易懂]
- Android Automotive OTA概念
- strictmode android,Android中的StrictMode
- android onresume方法,Android onActivityResult()和onResume()的执行顺序
- android vlc 中文字幕,解决Android版vlc中文乱码问题
- android 定时器的例子[通俗易懂]
- android view事件分发机制_android事件分发流程图
- Android触摸事件_android设置按钮点击事件
- Android ContentProvider_1 使用方法
- 错误记录 | Android Studio Start Failed com.intellij.ide.plugins.PluginManager
- Android studio更新后出现警告:Warning:The `android.dexOptions.incremental` property is deprecated and it has
- 【Android 应用开发】Canvas 绘制文字 ( 文字尺寸测量 | 基线绘制 )
- 【Android 电量优化】电量优化 ( 充电状态获取 | 主动获取充电状态 | 广播接受者监听充电状态 | 被动获取充电状态 | 注册空广播接受者获取历史广播 )
- 【错误记录】Android 应用安装报错 ( The application could not be installed: INSTALL_FAILED_CONFLICTING_PROVIDER )
- 【错误记录】p7zip 交叉编译 Android 版本 NDK 报错 ( error: case value evaluates to -2 , which cannot be narrowed )
- 【错误记录】Android Studio 编译报错 ( Gradle 下载错误导致 Failed to open zip file 报错 )
- 【错误记录】Android Studio 编译报错 ( Invalid main APK outputs : EarlySyncBuildOutput )
- 【错误记录】Android Studio 配置 AspectJ 报错 ( Failed to create Jar file C:xxxaspectjtools-1.8.10.jar. )
- 【错误记录】Android Studio 编译报错 ( Could not determine java version from ‘11.0.8‘. | 仅做参考 | 没有解决实际问题 )
- 【错误记录】Android Studio 编译报错 ( Execution failed for task ‘:APP_MIDI:lintVitalRelease‘. )
- 【错误记录】未安装该应用 ( 在 Android 12 之后 组件设置 android:exported=“false“ 属性 )
- 【错误记录】Android Studio 编译报错 ( AAPT: error: failed to read PNG signature: file does not start with PN )
- 【错误记录】Android 编译报错 ( Installed Build Tools revision 31.0.0 is corrupted | 修改 d8.bat、d8.jar 为 dx 名称 )
- 【错误记录】Android 应用安全检测漏洞修复 ( StrandHogg 漏洞 | 设置 Activity 组件 android:taskAffinity=““ )
- [android] 手机卫士绑定sim卡详解手机开发
- Android Studio 导入项目 出现安装Error:Cause: failed to find target with hash string ‘android-23’ 等错误详解手机开发
- 64位谷歌浏览器安卓版终于正式发布 但仅支持Android 10+和8GB+内存
- 安卓编年史(10):Android 2.0 Éclair——带动 GPS 产业
- android错误aapt.exe已停止工作的解决方法