【问题标题】:Android ndk can't find atof functionAndroid ndk找不到atof函数
【发布时间】:2025-11-23 12:20:03
【问题描述】:

我正在尝试在我的 Android 项目中使用开源 C 库。这个库使用atof() 函数。我知道atof() 是标准C 库(stdlib.h) 中定义的函数。因此,它应该在Android NDK(仿生库)上的标准C库中实现。

但是,当我尝试加载包含对此函数的调用的库时,我收到运行时错误:

java.lang.UnsatisfiedLinkError: Cannot load library: reloc_library[1285]:    86 cannot locate 'atof'....

我是使用 NDK 进行 Android 开发的初学者,所以我可能只是错过了标志、编译器指令等内容。

我的android.mk 文件是:

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_ALLOW_UNDEFINED_SYMBOLS := true

LS_CPP=$(subst $(1)/,,$(wildcard $(1)/$(2)/*.c))


LOCAL_MODULE := libA

LOCAL_SHARED_LIBRARIES :=       \
                            libgmodule-2.0          \
                            libgobject-2.0          \
                            libgthread-2.0          \
                            libglib-2.0

LOCAL_SRC_FILES:= sourceFile.c



include $(BUILD_SHARED_LIBRARY

【问题讨论】:

  • 你是如何构建这个项目的?您是否使用了独立的工具链,如 android-ndk-r8d/docs/STANDALONE-TOOLCHAIN.html 文件中所述?
  • 可能是您在其上运行应用程序的运行时系统的问题...因为“构建系统会自动将 C 库、数学库和 C++ 支持库链接到您的本机代码,那里不需要在 LOCAL_LDLIBS 行中列出它们。”
  • 很抱歉回答迟了。 LOCAL_ALLOW_UNDEFINED_SYMBOLS - 关闭未定义符号的检查,所以我错过了其他文件中 stdlib.h(atof) 的依赖项。是我的错。我确实错误地忽略了这个标志。复制和粘贴是真正的邪恶。
  • @void:你是不是建议不要使用LOCAL_ALLOW_UNDEFINED_SYMBOLS

标签: android android-ndk


【解决方案1】:

Google 已将一些 C 标准库函数(如 atof())从头文件中的内联函数移至普通函数。最新的 NDK 将默认构建一个 .so,它仅与最新的 Android 设备兼容,这些设备在设备的标准 C 库 (libc.so) 中具有 atof() 函数。这意味着如果您在具有旧版 C 库的旧设备上运行库,加载 dll 时会出错,因为预期的 atof() 函数不存在。

您是否尝试在 Application.mk 中进行设置:

APP_PLATFORM := android-9

这将导致 ndk 编译器构建与旧 Android 版本兼容的代码。

您也可以尝试将您的 NDK 安装降级到版本 10b(该版本早于 atof 从内联移动到 libc 的一部分的更改,因此完全避免了该问题)。

【讨论】:

  • 谢谢,对于新的 gradle 构建,您可以设置 ndk { platformVersion = "9" }
【解决方案2】:

来自stdlib.h in the Android source

static __inline__ double atof(const char *nptr)
{
    return (strtod(nptr, NULL));
}

atof 换句话说不是库函数,它是调用strtod 的内联函数。

如果您需要通过加载库来调用,只需使用strtod

【讨论】:

  • 这表明正在加载的库对象没有使用 NDK 编译,或者至少没有针对 NDK 头文件正确编译。虽然我有点惊讶,如果它是用另一个工具链构建的,它甚至会在特定功能上失败,而不是根本拒绝尝试加载。
  • @ChrisStratton 也让我感到惊讶,早于 r5 的 NDK only had a declaration, no implementation 但我怀疑使用的 NDK 并没有那么旧。
  • 我正在使用 ndk r8c。我刚刚下载它并使用 ndk-build -C "project path" 没有任何标志和修饰符..我错过了什么?
  • @void - 您是从源代码构建everything,还是下载预构建的.so 库?为开源库命名可能是个好主意,或者与它的维护者讨论这个问题。
  • 库的构建设置可能不正确,它在构建过程的一部分中使用了主机包含(即,用于您的 PC)而不是 android 包含。例如,如果有人在非交叉编译配置中运行了配置脚本,就会发生这种情况。