我们在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),运行时类型识别
CMake
设置。-fexceptions
标志添加到模块级build.gradle
文件的cppFlags
中,Gradle会将其传递到CMake。-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的基本类型可以直接与C/C++的基本类型映射。
与Java基本类型不同,引用类型对开发人员是不透明的。Java内部数据结构并不直接向原生代码开放。也就是说 C/C++代码并不能直接访问Java代码的字段和方法
专门为Android studio 开发c++ 时debug使用。只要在setting plugin中下载lldb ;