【android studio ndk-builld方式开发】万事须己运,他得非我贤。这篇文章主要讲述android studio ndk-builld方式开发相关的知识,希望能为你提供帮助。
之前都是在Ubuntu开发,项目也是老的,自然也就顺理成章的用eclipse做各种android的开发。最近想在android studio 切换下,有点不习惯。android studio 为ndk开发提供了两种不同的方式,使用cmake自动编译脚本 和类似eclipse上的ndk-build。这两者之间使用区别在于,如果想直接开发新的单模块可以考虑使用cmake,ide有自带辅助插件,让程序员使用起来更加舒心。如果想在第三方源码库上面做二次开发,或者需要多个源码库关联,感觉还是使用ndk-build会更加灵活,或者说老经验不用重新踩那么多坑。
关于环境搭建的可以参考android 开发者文档,里面有详细的说明
https://developer.android.google.cn/studio/projects/add-native-code.html#link-gradle
下面就在android studio建一个ndk的sample项目。
1、新建一个一般项目,添加jni文件夹以及子目录include 存放头文件,src存放源码
文章图片
2、在java代码中,新建 TestJni类调用native方法,并使用javah命令生成头文件
文章图片
3创建相应的方法文件 回到main目录下
文章图片
? classpath:类搜索路径,这里表示从当前的 bin 目录下查找 ? d:将生成的头文件放到当前的 jni 目录下 ? o: 指定生成的头文件名称,默认以类全路径名生成(包名+类名.h)注意: -d 和-o 只能使用其中一个参数。刷新下android studio的项目目录就可以看到
文章图片
上面javah的指令,为了后面方便使用,可以在external tools中自定义。File-> Setting-> Tools -> External Tools 点击添加
文章图片
这样就可以在需要包含native方法的的文件中右键使用 4 cmake方法会根据脚本提供自动生成的Android.mk脚本,不过ndk-build 方法就需要自己编写编译配置脚本Android.mk LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_C_INCLUDES += $(LOCAL_PATH)/include \\ $(LOCAL_PATH)/src LOCAL_SRC_FILES := src/hello-jni.c LOCAL_MODULE := NativeLib include $(BUILD_SHARED_LIBRARY) Android.mk文档必须以LOCAL_PATH变量的定义开头。 LOCAL_PATH := $(call my-dir) Android 构建系统利用LOCAL_PATH来定位源文件。因为将该变量设置为硬编码值并不合适,所以Android构建系统提供了一个名为 my-dir 的宏功能。通过将该变量设置为my-dir宏功能的返回值,可以将其放在当前目录下。 Android 构建系统将CLEAR_VARS变量设置为clear_vars.mk片段的位置。包含Makefile片段可以清除除了LOCAL_PATH 以外的LOCAL_< name> 变量,例如LOCAL_SRC_FILES,LOCAL_MODULE 等。 include $(CLEAR_VARS)这样做是因为 Android构建系统在单次执行中解析多个构建文件和模块定义,而LOCAL_< name> 是全局变量。清楚他们可以避免冲突,每一个原生组件被称为一个模块。 LOCAL_MODULE 变量用来给这些模块设定一个唯一的名称。下面的代码将该模块的名称设为NativeLib。 LOCAL_MODULE := NativeLib 其实 LOCAL_MODULE := libNativeLib 结果也是可以的,编译的生成结果,构建系统会自动添加适当的前缀后缀生成动态共享文件 ,如果前面已经添加lib,那么还会是原样,如:libNativeLib.so。可以在路径 "项目路径\\unit2\\app\\build\\intermediates\\ndkBuild\\debug\\obj\\local\\架构类型\\"看到。 用LOCAL_C_INCLUDES 指定头文件的搜索路径,LOCAL_SRC_FILES指定源文件列表,多个文件可以使用空格分开的多个源文件名字。 到这里,就简单描述了一个原生项目。编译和生成实际模块的构建系统还需要包含合适的构建系统片段,具体取决于想要生成的模块的类型。 include $(BUILD_SHARED_LIBRARY)其中BUILD_SHARED_LIBRARY是一个指向生成共享文件的脚本。 有下面三种文件生成格式 BUILD_STATIC_LIBRARY:编译为静态库。
BUILD_SHARED_LIBRARY :编译为动态库 BUILD_EXECUTABLE:编译为Native C可执行程序 这里就不展开了 在android studio编译原生项目,还需要配置module(app)目录下的build.gradle。下面是需要添加的内容 android { defaultConfig { ndk{ abiFilters "armeabi","armeabi-v7a","x86" } } externalNativeBuild{ ndkBuild{ path "src/main/jni/Android.mk" } } }apk在不同硬件平台运行时,要根据cpu架构调用不同的共享文件。 ndk{ abiFilters "armeabi","armeabi-v7a","x86" }就会生成三种适合不同cpu架构的共享文件,
文章图片
不配置的话,系统将会默认生成支持的所有架包,如果ndk配置发生改变,要clean project
文章图片
externalNativeBuild{ ndkBuild{ path "src/main/jni/Android.mk" } } 选择cmake还是ndk-build都需要在这里面写明脚本路径 接下来就跑跑项目看效果。
推荐阅读
- CentOS7/RHEL7如何修改swappiness值()
- 如何修复Mac上的“你的系统已用完应用程序内存”错误()
- 如何将Windows 11恢复出厂设置(操作方法分步指南)
- 如何在Windows 11上打开蓝牙(4种简单方法指南)
- 如果我的Mac不断重启怎么办(解决问题的10个技巧)
- 如何在Windows 11中清除缓存(7种有效方法指南)
- 为什么我的Mac风扇声音这么大(修复Mac过热的14种方法!)
- Microsoft Store无法在Windows 11中运行(这是解决方法指南)
- 如何在Windows 11中删除“未满足系统要求”水印(解决方法)