前几天我们学习了c的基础知识和jni的一些基本数据类型的对应关系。接下来几天开始进如JNI的练习。
学习之前我们要先来弄懂要学什么?
接下来分析下:
一、java调用c
二、c调用java
三、自己编写c的内容。
我们前期先主要围绕前两种来学习。
学习之前我们首先要做的就是学习怎么打印Log日志,当然这个Log是在Jni中打印的。我们知道c的打印一般就是printf()
但是这个方法在Android studio中没法显示结果的。
----------------------------------------------------话不多说撸代码-------------------------------------------------
1.1:如果你的开发工具是Android studio 并且你的NDK配置文件是CMakeLists.txt可以用下面的方法
find_library( # Sets the name of the path variable.
log-lib
# Specifies the name of the NDK library that
# you want CMake to locate.
log )
在这里面引入你的log
1.2:接着在你需要打印的.cpp文件下引入
#include <android/log.h>
#include <jni.h>这个开发中会用到
#define TAG "我的LOG日志"//这个TAG的内容自己随便定义,跟我们Android的tag一样
// 本人喜欢用LOGE的所以这边用了ANDROID_LOG_ERROR error级别的打印。
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,TAG,__VA_ARGS__)
其他的两个定义方式:
// 定义info信息
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,TAG,__VA_ARGS__)
// 定义debug信息
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, TAG, __VA_ARGS__)
ANDROID_LOG_INFO:是日志级别;
TAG:是要过滤的标签,可以在LogCat视图中过滤。
__VA_ARGS__:是实际的日志内容。
LOGE(...) ...代表个数可变参数。
比如接下来我们要打印一个数值:
jint i=1;
LOGE("我的int值是%d",i);
1.3日志类型
1)Log.v 的调试颜色为黑色的,任何消息都会输出,这里的v代表verbose啰嗦的意思,平时使用就是Log.v(,);
2)Log.d的输出颜色是蓝色的,仅输出debug调试的意思,但他会输出上层的信息,过滤起来可以通过DDMS的Logcat标签来选择
3)Log.i的输出为绿色,一般提示性的消息information,它不会输出Log.v和Log.d的信息,但会显示i、w和e的信息
4)Log.w的意思为橙色,可以看作为warning警告,一般需要我们注意优化Android代码,同时选择它后还会输出Log.e的信息。
5)Log.e为红色,可以想到error错误,这里仅显示红色的错误信息,这些错误就需要我们认真的分析,查看栈的信息了。
LOGI("user info----name:%s, age:%d, sex:%s.", "xxx", 18, "男");
对应的占位符可以查看我之前写的,或者到网上搜一下吧。
注意:log打印的方法中不能传入jstring,必须将jstring转为c中的字符数组在传入到方法里面打印,否则会报错。
2.1:如果你的开发工具是Android studio 并且你的NDK配置文件是Android.mk可以用下面的方法
如生成的库文件是“.so文件”,则在Android.mk中添加如下内容:
LOCAL_LDLIBS:=-L$(SYSROOT)/usr/lib -llog
如生成的库文件是“.a文件”,则在Android.mk中添加如下内容:
LOCAL_LDLIBS:=-llog
defaultConfig {
applicationId "im.weiyuan.com.jni"
minSdkVersion 16
targetSdkVersion 25
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
ndk{
moduleName "hello" //设置库(so)文件名称
abiFilters "armeabi", "armeabi-v7a", "x86"
ldLibs "log"
}
}
其他的操作跟1.1的雷同了。
这时篇幅太长了,另开一章咯~~~。