上次记述了在Android Studio下使用NDK是一种怎样的体验,
过程较为繁琐,需要记住比较多的指令,这是比较头疼的地方。
上次更新SDK工具的时候无意中发现列表下有一个CMake的选项,从命名中就明显感觉到这应该和C相关,心想莫非此工具已经有更好的方法编写C函数了?于是乎下载,网上一顿乱气之后,大概是知道了一点皮毛,深感其用法之简单,绝非NDK常规用法所能比的,大喜,遂记之。
----于20170109
示例demo传送门---------go ----HelloCMake
1、配置
a)下载CMake,最好是使用Android Studio下载
File->Settings->Appearance&Behavior->System Settings->Android SDK->SDK Tools勾选CMake
b)在module下新建cpp文件夹,用于存放.cpp文件。
c)配置build.gradle,加入
defaultConfig{
externalNativeBuild {
cmake {
cppFlags ""
}
}
}
android{
externalNativeBuild {
cmake {
path "CMakeLists.txt"
}
}
}
d)建立cpp文件
在main/java同级下的cpp文件夹下新建cpp文件,so-demo.cpp
e)编写CMakeLists.txt文件
例子如下
#CMake版本
cmake_minimum_required(VERSION 3.4.1)
#添加的cpp文件
add_library( so-demo SHARED src/main/cpp/so-demo.cpp )
#log
find_library( log-lib log )
#生成的目标so
target_link_libraries( so-demo ${log-lib} )
2、编写cpp
a)新建类,声明cpp方法,public native ... 关键字 native
package amos.com.hellocmake.soutil;
/**
* @author kuan.liang
*/
public class SoUtils {
private static SoUtils instance = null;
public static SoUtils getInstance(){
if(null == instance){
synchronized (SoUtils.class){
if(null == instance){
instance = new SoUtils();
}
}
}
return instance;
}
//测试方法
public native String getStringFromJni();
}
b)编写cpp,Android Studio下鼠标移至native函数,Alt+Enter使用智能提示可快速生成函数,如下,将方法置于extern "C"{}内,使用C的形式编写代码
#include <jni.h>
#include <string>
extern "C"{
JNIEXPORT jstring JNICALL
Java_amos_com_hellocmake_soutil_SoUtils_getStringFromJni(JNIEnv *env, jobject) {
std::string hello = "Say hello from JNI";
return env->NewStringUTF(hello.c_str());
}
}
3、构建运行
首先需要引用生成的so库,适当地方加载。按照构建apk的办法进行构建,可直接run,也可以使用Gradle等。
// 务必在方法调用之前加载
System.loadLibrary("so-demo");
构建完成,可以在build/intermediates/cmake下得到相应的so库,可拷贝至其他工程使用。
4、结束
使用CMake大大降低了编写C的难度,而且配置简单,亦可以不写一大堆的.h头文件了,不失为一种较优的选择。
源代码OSGit地址:AndroidNDK - HelloCMake