本文目录
一、androidstudio环境
二、快捷键配置
三、新建项目
四、NDK开发
五、so文件编译
一、 androidstudio的环境
在SDK Tools中安装NDK开发环境(File > Settings > Appearance & Behavior > System Settings > Android SDK > SDK Tools): NDK
二、快捷键的配置
打开File > Settings > Tools > External Tools选项,点击【+】按钮添加生成jni头文件以及ndk-build命令的快捷工具:
①生成头文件
Name:javah-jni
工具名称
Program:$JDKPath$/bin/javah
javah所在的路径,$JDKPath$代表在环境变量中配置的JDK路径。
Parameters:-jni -encoding UTF-8 -d $ModuleFileDir$srcmainjni $FileClass$
命令参数:
-jni代表生成JNI样式的标头文件,文件名为当前包名+类名($FileClass$)
•-encoding代表编码格式为UTF-8
•-d代表指定头文件的输出路径为jni目录($ModuleFileDir$srcmainjni )
Working directory:$ModuleFileDir$srcmainjava
工作目录,$ModuleFileDir$为当前module的路径。
②NDK构建
ndk-build的配置和javah-jni类似,其中C:ToolsNDKandroid-ndk-r14b dk-build.cmd为ndk-build构建工具的路径,需要按照实际NDK安装路径进行修改。
③如何调用
右击项目选择External Tools:
三、新建一个普通的项目
①在main目录下新建jni目录,在此目录下编写原生代码:
②在main目录下新建jniLibs目录,此目录为Android Stuido加载so文件的默认目录,看下项目结构
四、NDK开发
①MainActivity
public class MainActivity extends AppCompatActivity { // 加载native-lib,不加lib前缀 static { System.loadLibrary("native-lib"); } @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 将获取的字符串显示在TextView上 TextView tv = findViewById(R.id.sample_text); tv.setText(stringFromJNI()); } /** * native-lib中的原生方法 */ public native String stringFromJNI(); }
②对着MainActivity的类名右击鼠标,选择External Tools > javah-jni,控制台执行完命令后,会在jni目录生成一个头文件:
③jni目录中新建cpp类native-lib.cpp,引用上文中生成的头文件,返回一个字符串给Java层,
④接着在jni目录下创建Android.mk和Application.mk配置文件
Android.mk
# 当前路径 LOCAL_PATH := $(call my-dir) # 清除LOCAL_XXX变量 include $(CLEAR_VARS) # 原生库名称 LOCAL_MODULE := native-lib # 原生代码文件 LOCAL_SRC_FILES =: native-lib.cpp # 编译动态库 include $(BUILD_SHARED_LIBRARY)
Application.mk
# 原生库名称 APP_MODULES := native-lib # 指定机器指令集 APP_ABI := armeabi armeabi-v7a arm64-v8a x86 x86_64 mips mips64
⑤在app的build.gradle文件中关联Android.mk(相当于执行了【Link C++ Project with Gradle】)
android { ... externalNativeBuild { ndkBuild { path 'src/main/jni/Android.mk' } }
五、so文件编译
①对着jni目录右击鼠标,选择External Tools > ndk-build,会在main目录下生成libs和obj目录,编译出的so文件就在libs目录下
②将so文件拷贝到jniLibs目录下就可以正常使用了,也可以在app的build.gradle文件中设置so文件的路径。
注意:编译出的so文件就相当于java中的jar包,上文中的jni就相当于library,两者不要重复使用。
原文链接:https://blog.csdn.net/kong_gu_you_lan/article/details/79146817