1.Android.mk 文件的配置

LOCAL_LDLIBS += -llog

如果是使用Android Studio的NDK配置,在app中的build.gradle中的ndk的配置项中加入ldLibs "log"

ndk {      moduleName "hello-jni"      ldLibs "log"  // 使用Android Log}

2.JNI层C/C++文件配置

需要添加输出函数的文件中加入头文件:

#include <android/log.h>

3.使用方法

__android_log_print(ANDROID_LOG_INFO, “tag”, “content”);

  1. 第一个参数取如下值:
typedef enum android_LogPriority {    ANDROID_LOG_UNKNOWN = 0,    ANDROID_LOG_DEFAULT,    /* only for SetMinPriority() */    ANDROID_LOG_VERBOSE,    ANDROID_LOG_DEBUG,    ANDROID_LOG_INFO,    ANDROID_LOG_WARN,    ANDROID_LOG_ERROR,    ANDROID_LOG_FATAL,    ANDROID_LOG_SILENT,     /* only for SetMinPriority(); must be last */} android_LogPriority;
  • 第二个参数为tag
  • 第三个参数为内容,支持格式化输出
    如__android_log_print(ANDROID_LOG_INFO, “JNI_LOG”, “Tip: %s “, msg);

一般我们会声明一些宏来输出log,简化书写:

#ifndef LOG#define LOG_TAG "jni"#define ALOGD(...) \            __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__);#define ALOGE(...) \            __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__);#define ALOGV(...) \            __android_log_print(ANDROID_LOG_VERBOSE, LOG_TAG, __VA_ARGS__);#endif LOG

这样就可以使用ALOGD,ALOGE,ALOGV等来输出log

更多相关文章

  1. Android定时器Timer.schedule
  2. python logging 模块(一)
  3. Android(安卓)OPenCV 环境配置
  4. mac下配置android studio工具
  5. android 控制EditText字符长度[配置控制 代码控制]
  6. Android使用百度地图---环境配置和Hello World
  7. Android(安卓)Studio下载、安装和配置+SDK+tools下载(无敌超级详
  8. 发邮件
  9. Android(安卓)Looper And Hander 机制剖析 - 03

随机推荐

  1. 210330 CSS grid布局仿写
  2. 附解决方案,小程序获取的用户信息中昵称图
  3. 工具之_文本处理工具
  4. 【JS基础入门】JavaScript基础之值与引用
  5. ensp起不来的原因汇总(长期更新)
  6. 为什么对象存储一定要成为2018年数据战略
  7. 简化数据获取!Uber开源深度学习分布训练库
  8. LinkedIn开源TonY:在Hadoop上运行TensorFl
  9. Kafka落选!InfoWorld最佳开源数据平台奖公
  10. 基于角色访问控制RBAC权限模型的动态资源