如何获取在NDK应用程序中写的" printf"消息?

 2023-01-21    297  

问题描述

如果我在Java文件中定义此功能

/** 
   * Adds two integers, returning their sum
   */
  public native int add( int v1, int v2 );

所以我需要在C文件中进行编码

如何获取在NDK应用程序中写的" printf"消息?

JNIEXPORT jint JNICALL Java_com_marakana_NativeLib_add
  (JNIEnv * env, jobject obj, jint value1, jint value2) {

  printf("\n this is log messge \n");

        return (value1 + value2);
}

然后从何处打印消息?
在登录中我不明白吗?

如何通过添加日志消息来调试任何NDK应用程序?

推荐答案

而不是使用__android_log_print().您必须包括标题<android/log.h>

示例示例. __android_log_print(ANDROID_LOG_DEBUG, “LOG_TAG”, “\n this is log messge \n”);

您也可以使用格式指定符,例如printf-

__android_log_print(ANDROID_LOG_DEBUG, "LOG_TAG", "Need to print : %d %s",int_var, str_var);

确保您还在android.mk文件中链接到日志库:

LOCAL_LDLIBS := -llog

ohh ..忘记..输出将以Logcat显示标签LOG_TAG

易于方法

将以下行添加到您的公共标题文件中.

#include <android/log.h>

#define  LOG_TAG    "your-log-tag"

#define  LOGD(...)  __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__)
#define  LOGE(...)  __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__)
// If you want you can add other log definition for info, warning etc

现在只调用LOGD(“Hello world”) or LOGE(“Number = %d”, any_int)喜欢printf in c.

不要忘记包括公共标题文件.

删除记录

如果您定义LOGD(…)空,则所有日志都将消失.只需在LOGD(…)之后发表评论.

#define LOGD(…) // __android_log….. rest of the code

其他推荐答案

有两个选项:

1)用__android_log_print替换printf.您可以在代码开始时轻松地执行此操作:

#define printf(...) __android_log_print(ANDROID_LOG_DEBUG, "TAG", __VA_ARGS__);

当然,这将需要更改具有printf的所有源代码.

2)将stdout和stderr重定向到android logcat(不确定这是否可以在非根系上使用):其他推荐答案

无需扎根设备,将杂物编码为 http:http:http:http://开发者. android.com/guide/developing/debugging/debugging-log.html#viewingstd ,以下可以预先工作.

$ adb shell 

$ su 

$ stop

$ setprop log.redirect-stdio true

$ start

完成!

以上所述是小编给大家介绍的如何获取在NDK应用程序中写的" printf"消息?,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对77isp云服务器技术网的支持!

原文链接:https://77isp.com/post/26324.html

=========================================

https://77isp.com/ 为 “云服务器技术网” 唯一官方服务平台,请勿相信其他任何渠道。