Android.mk 除了PREBUILT_SHARED_LIBRARY还有哪些
时间: 2023-11-29 09:07:05 浏览: 158
除了 PREBUILT_SHARED_LIBRARY,Android.mk 文件中还可以使用以下模块指令:
- BUILD_SHARED_LIBRARY:用于编译生成共享库(.so)文件;
- BUILD_STATIC_LIBRARY:用于编译生成静态库(.a)文件;
- BUILD_EXECUTABLE:用于编译生成可执行文件;
- LOCAL_MODULE_TAGS:用于给模块打标签,方便在 Android 系统中选择性加载;
- LOCAL_C_INCLUDES:用于指定 C 语言头文件的搜索路径;
- LOCAL_CFLAGS:用于指定 C 语言编译器的编译选项;
- LOCAL_CPPFLAGS:用于指定 C++ 语言编译器的编译选项;
- LOCAL_STATIC_LIBRARIES:用于指定静态库的依赖关系;
- LOCAL_SHARED_LIBRARIES:用于指定共享库的依赖关系;
- LOCAL_LDLIBS:用于指定链接时需要加入的库文件。
- include $(BUILD_PACKAGE):用于生成 APK 文件。
还有其他一些模块指令,具体可以参考 Android 官方文档。
相关问题
android .mk文件加LD_LIBRARY_PATH
在 Android 的 .mk 文件中,无法直接设置 LD_LIBRARY_PATH 环境变量,因为编译和运行 Android 应用时,动态链接库(共享库)的加载路径由系统自动管理。
Android 使用 `System.loadLibrary()` 或 `System.load()` 方法来加载共享库。系统会根据库的命名规范和位置进行库的搜索和加载。通常,Android 应用的共享库应该存放在 `/system/lib`、`/system/lib64` 或应用的私有目录 `/data/data/<package_name>/lib` 中。
如果你需要在 Android 应用中加载自定义的共享库,可以按照以下步骤操作:
1. 将共享库文件放置在应用的 `jniLibs` 目录下(如果没有该目录,可以手动创建)。
2. 在 Android.mk 文件中添加以下代码:
```makefile
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := mylibrary
LOCAL_SRC_FILES := path/to/mylibrary.so
include $(PREBUILT_SHARED_LIBRARY)
```
其中,`path/to/mylibrary.so` 是共享库文件的路径。这样,Makefile 会将共享库文件打包到 APK 中,并在运行时自动加载。
请确保将 `mylibrary` 替换为你的共享库名称,将 `path/to/mylibrary.so` 替换为实际的共享库文件路径。
重要提示:在 Android 中使用 NDK(Native Development Kit)编译生成的共享库通常会自动处理动态链接路径,因此不需要手动设置 LD_LIBRARY_PATH。系统会自动查找和加载应用所需的共享库。
cc_prebuilt_library_shared { name: "libTSDesensitizationAlgorithm", srcs: ["libTSDesensitizationAlgorithm.so"], compile_multilib : "64", }转为Android.mk
以下是将cc_prebuilt_library_shared转换为Android.mk的示例:
```
include $(CLEAR_VARS)
LOCAL_MODULE := libTSDesensitizationAlgorithm
LOCAL_SRC_FILES := libTSDesensitizationAlgorithm.so
LOCAL_MULTILIB := 64
include $(PREBUILT_SHARED_LIBRARY)
```
其中,PREBUILT_SHARED_LIBRARY是一个预定义的Makefile规则,用于构建预编译的共享库模块。LOCAL_MULTILIB用于指定模块所属的multilib架构。
阅读全文