Android - NDK:在Jni中打印Log信息

在Jni中打印Log信息

1、在配置CMakeLists.txt

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)

# Specifies libraries CMake should link to your target library. You
# can link multiple libraries, such as libraries you define in this
# build script, prebuilt third-party libraries, or system libraries.

target_link_libraries( # Specifies the target library.
        ndktest
        # Links the target library to the log library
        # included in the NDK.
        ${log-lib})

2、在jni层的cpp文件中定义

c 复制代码
#include <android/log.h>

#define LOG_TAG "MyJNILog"
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO,LOG_TAG ,__VA_ARGS__) // 定义LOGI类型
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG ,__VA_ARGS__) // 定义LOGD类型
#define LOGW(...) __android_log_print(ANDROID_LOG_WARN,LOG_TAG ,__VA_ARGS__) // 定义LOGW类型
#define LOGE(...) __android_log_print(ANDROID_LOG_ERROR,LOG_TAG ,__VA_ARGS__) // 定义LOGE类型
#define LOGF(...) __android_log_print(ANDROID_LOG_FATAL,LOG_TAG ,__VA_ARGS__) // 定义LOGF类型

3、在jni中使用

复制代码
LOGI("strPre = %s", buf);  // 输出字符串

LOGI("in native , a = %f,b= %f", a, b);  // a和b为double类型或float类型

LOGI("len1 = %d, len2 = %d", len1, len2);  // 输出int类型
相关推荐
alexhilton7 小时前
Compose中初始加载逻辑究竟应该放在哪里?
android·kotlin·android jetpack
zh_xuan8 小时前
启动RN服务端口被占用
android·react native
Code-keys10 小时前
Android Codec2 Filter 算法模块开发指南
android·算法·音视频·视频编解码
y = xⁿ11 小时前
MySQL:count(1)与count(*)有什么区别,深分页问题
android·数据库·mysql
程序员陆业聪13 小时前
Android启动全景图:一次冷启动背后到底发生了什么
android
安卓程序员_谢伟光15 小时前
m3颜色定义
android·compose
麻辣璐璐16 小时前
EditText属性运用之适配RTL语言和LTR语言的输入习惯
android·xml·java·开发语言·安卓
北京自在科技16 小时前
谷歌 Find Hub 网页端全面升级:电脑可直接管理追踪器与耳机
android·ios·安卓·findmy
Rush-Rabbit16 小时前
魅族21Pro刷ColorOS16.0操作步骤
android
爪洼传承人16 小时前
AI工具MCP的配置,慢sql优化
android·数据库·sql