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 字符串然后打印(转换方式看前文)。

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

  • 相关阅读:
    c++ 文件读写模板
    sys和system用户的权限区别
    Oracle cmd 命令
    sqldeveloper的安装及其使用教程
    Oracle权限管理详解(2)
    Oracle权限管理详解(1)
    Oracle使用基础
    win7 64位操作系统中 Oracle 11g 安装教程(图解)
    MySQL cmd操作
    Linux下安装tomcat
  • 原文地址:https://www.cnblogs.com/lenve/p/4889325.html
Copyright © 2011-2022 走看看