Eclipse中NDK开发使用Application.mk指定需要编译的平台

ABI(Application Binary Interface)实际就是指应用程序基于哪种指令集来进行编译,我们能用到的ABI 也就四种 armeabi armeabi-v7a x86 和mips ,前两者是最常见的。

其次这4个编译选项的含义:
1.‘armeabi’ – 默认选项,将创建以基于 ARM* v5TE 的设备为目标的库。 具有这种目标的浮点运算使用软件浮点运算。 使用此 ABI 创建的二进制代码将可以在所有 ARM* 设备上运行。
2.‘armeabi-v7a’ – 创建支持基于 ARM* v7 的设备的库,并将使用硬件 FPU 指令。
3.‘x86’ – 生成的二进制代码可支持包含基于硬件的浮点运算的 IA-32 指令集.
4.mips — 支持应用二进制接口

总结:
APP_ABI 赋值,就是为了交叉编译生成相应芯片可执行的指令集。

在jni目录新建Application.mk 写入: APP_ABI := armeabi armeabi-v7a mips x86 那么在你的android工程下边的 libs 里边会出现 armeabi armeabi-v7a mips x86 这四个目录下会分别生成 4个.so文件。

程序在Android手机运行时,根据手机自身CPU芯片不同,去选择调用相应的.so文件。需要注意的是选择的平台越多,so库也越多,打包的apk体积也越大。

NdkDemo代码已上传至Github

如有不正支出,欢迎留言交流!
我的GitHub
我的CSDN
我的简书
开发笔记

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在进行NDK开发时,Android.mk文件是非常重要的一个文件,它用来描述你的Native代码库的模块依赖关系、编译选项等信息。下面是Android.mk文件编写的一些基本规则和示例。 1. Android.mk文件基本结构 Android.mk文件由一系列的变量定义、模块声明和编译选项等组成。下面是一个基本的Android.mk文件结构: ``` LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := mymodule LOCAL_SRC_FILES := mymodule.c LOCAL_LDLIBS := -llog -landroid include $(BUILD_SHARED_LIBRARY) ``` 其,`LOCAL_PATH`指定了当前目录路径;`CLEAR_VARS`清除之前的变量定义;`LOCAL_MODULE`指定了模块名称;`LOCAL_SRC_FILES`指定了源代码文件;`LOCAL_LDLIBS`指定了链接库;`BUILD_SHARED_LIBRARY`指定编译成共享库。 2. 添加多个源文件 如果一个模块由多个源文件组成,可以使用`LOCAL_SRC_FILES`变量指定多个源文件,例如: ``` LOCAL_SRC_FILES := file1.c \ file2.c \ file3.c ``` 3. 添加头文件路径 如果源文件包含了其他头文件,可以使用`LOCAL_C_INCLUDES`变量指定头文件路径,例如: ``` LOCAL_C_INCLUDES := $(LOCAL_PATH)/include ``` 4. 添加编译选项 如果需要添加编译选项,可以使用`LOCAL_CFLAGS`和`LOCAL_CPPFLAGS`变量,例如: ``` LOCAL_CFLAGS := -Wall -O2 LOCAL_CPPFLAGS := -std=c++11 ``` 5. 添加链接库 如果需要链接其他库,可以使用`LOCAL_LDLIBS`变量,例如: ``` LOCAL_LDLIBS := -llog -landroid ``` 6. 添加静态库 如果需要链接静态库,可以使用`LOCAL_STATIC_LIBRARIES`变量,例如: ``` LOCAL_STATIC_LIBRARIES := libfoo libbar ``` 7. 使用编译头文件 如果需要使用编译头文件,可以使用`LOCAL_CXX_FLAGS`变量,例如: ``` LOCAL_CXX_FLAGS += -include myheader.h ``` 8. 模块依赖关系 如果一个模块依赖于另外一个模块,可以使用`LOCAL_STATIC_LIBRARIES`或`LOCAL_SHARED_LIBRARIES`变量来声明依赖关系,例如: ``` include $(CLEAR_VARS) LOCAL_MODULE := libfoo LOCAL_SRC_FILES := foo.c include $(BUILD_STATIC_LIBRARY) include $(CLEAR_VARS) LOCAL_MODULE := libbar LOCAL_SRC_FILES := bar.c LOCAL_STATIC_LIBRARIES := libfoo include $(BUILD_SHARED_LIBRARY) ``` 上面的例子,模块`libbar`依赖于模块`libfoo`。 以上就是Android.mk文件编写的一些基本规则和示例,希望能够对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员学园

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值