zoukankan      html  css  js  c++  java
  • NDK开发之日志打印

    要在NDK中打印日志,只需要以下三步:


    一、在Android.mk中添加以下内容:

    LOCAL_LDLIBS := -lm -llog
    
    或者
    
    LOCAL_LDLIBS:=-L$(SYSROOT)/usr/lib -llog

    以上两行代码二选一。
    注意,这行代码要添加在include $(CLEAR_VARS)之后,否则没有效果。比如我有一个c文件,一个cpp文件,分别是jni1.c和jni3.cpp,那么你要打印日志应该这样添加:

    include $(CLEAR_VARS)
    LOCAL_LDLIBS := -lm -llog
    LOCAL_MODULE    := jni1
    LOCAL_SRC_FILES := jni1.c
    
    include $(BUILD_SHARED_LIBRARY)
    include $(CLEAR_VARS)
    LOCAL_LDLIBS:=-L$(SYSROOT)/usr/lib -llog
    LOCAL_MODULE    := jni3
    LOCAL_SRC_FILES := jni3.cpp
    
    include $(BUILD_SHARED_LIBRARY)

    二、引用头文件

    #include <android/log.h>

    三、定义变量

    //定义TAG之后,我们可以在LogCat通过TAG过滤出NDK打印的日志
    #define TAG "JNITEST"
    // 定义info信息
    #define LOGI(...) __android_log_print(ANDROID_LOG_INFO,TAG,__VA_ARGS__)
    // 定义debug信息
    #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, TAG, __VA_ARGS__)
    // 定义error信息
    #define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,TAG,__VA_ARGS__)

    ANDROID_LOG_INFO是日志级别,这和LogCat中是一一对应的,TAG是过滤标签,__VA_ARGS__是我们要打印的实际的日志内容。


    OK!

    做完上面三步可以打印日志了:

    LOGI("the string is :%s",str1);

    注意:打印日志时如果是字符串切不可打印jstring,要将jstring转换为C 字符串然后打印(转换方式看前文)。

    版权声明:本文为博主原创文章,未经博主允许不得转载。若有错误地方,还望批评指正,不胜感激。

  • 相关阅读:
    P1536 村村通 题解
    P1551 亲戚题解
    P1185 绘制二叉树 题解
    P3884 [JLOI2009]二叉树问题
    P1087 [NOIP2004 普及组] FBI 树
    P1305 新二叉树题解
    P1229 遍历问题
    P1030 [NOIP2001 普及组] 求先序排列题解
    P1827 [USACO3.4]美国血统 American Heritage 题解
    深度优先搜索dfs 讲解教程
  • 原文地址:https://www.cnblogs.com/lenve/p/4889325.html
Copyright © 2011-2022 走看看