我们在build.gradle
里面看到,有两个地方用到了externalNativeBuild
,一个是在defaultConfig
里面,是一个是在defaultConfig
外面。
- 在
defaultConfig
外面的externalNativeBuild
里面的cmake
指明了CMakeList.txt
的路径(在本项目下,和是build.gradle
在同一个目录里面)。 - 在
defaultConfig
里面的externalNativeBuild
里面的cmake
主要填写的是CMake
的命令参数。即由arguments中的参数最后转化成一个可执行的CMake的命令,可以在
defaultConfig外面的 externalNativeBuild - cmake,指明了 CMakeList.txt 的路径; defaultConfig 里面的 externalNativeBuild - cmake,主要填写 CMake 的命令参数。异常处理,即由 arguments 中的参数最后转化成一个可执行的 CMake 的命令,可以在 app/externalNativeBuild/cmake/debug/{abi}/cmake_build_command.txt
中查到。如下
defaultConfig {
applicationId "com.itep.myapplication"
minSdkVersion 15
targetSdkVersion 26
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
externalNativeBuild {
cmake {
cppFlags "-frtti -fexceptions"
}
}
}
externalNativeBuild {
cmake {
path "CMakeLists.txt"
}
}
RTTI(Run-Time Type Identification),运行时类型识别
- C++ Standard:即C++标准,使用下拉列表选择你希望使用的C++的标准,选择Toolchain Default 会使用默认的
CMake
设置。 - Exceptions Support:如果你希望启用对C++异常处理的支持,请选择此复选框。如果启动此复选框,Android Studio 会将
-fexceptions
标志添加到模块级build.gradle
文件的cppFlags
中,Gradle会将其传递到CMake。 - Runtime Type Information Support:如果开发者希望支持RTTI,请选中此复选框。如果启用此复选框,Android Studio 会将
-frtti
标志添加到模块级build.gradle
文件的cppFlags中,Gradle会将其传递到CMake。
Java代码:
public native void showHello();
public native static void showHello2();
C++代码:
extern "C"
JNIEXPORT void JNICALL
Java_com_kgdwbb_jnistudy_MainActivity_showHello(JNIEnv* env, jobject thiz) {
//do something
}
extern "C"
JNIEXPORT void JNICALL
Java_com_kgdwbb_jnistudy_MainActivity_showHello2(JNIEnv* env, jclass thiz) {
//do something
}
Java 和JNI基本类型对照表
java的基本类型可以直接与C/C++的基本类型映射。
Java与JNI引用类型对照表
与Java基本类型不同,引用类型对开发人员是不透明的。Java内部数据结构并不直接向原生代码开放。也就是说 C/C++代码并不能直接访问Java代码的字段和方法
专门为Android studio 开发c++ 时debug使用。只要在setting plugin中下载lldb ;
JNI常用函数:https://wenku.baidu.com/view/2853bc262f60ddccda38a00d.html