
我们在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 ;