1

打印到 stderr 的原始代码:

extern "C" {
/* error: output error message */
void Error(const int error, char *message, ...)
{
    va_list arg;
   fflush(stdout);
   fflush(stderr);

   if (error > 0)
     fprintf(stderr, "\nError: ");
   else
     fprintf(stderr, "\nWarning: ");

   va_start(arg, message);
   vfprintf(stderr, message, arg);
   va_end(arg);

   fflush(stderr);
   if (error > 0)
      exit(error);
}

void main(){
Error(0,"Problem %s in file", "sometext");
}

}//extern "C"

我修改了我的代码看起来像这样。它应该打印到 logcat

extern "C" {
#include <android/log.h>
#include <jni.h>
#include <sys/types.h>

#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#include <math.h>

/* error: output error message */
void Error(const int error, char *message, ...)
{
    va_list arg;

   va_start(arg, message);
   if (error > 0)
   __android_log_print(ANDROID_LOG_ERROR, "HTS_API", message, arg);
      else
   __android_log_print(ANDROID_LOG_WARN, "HTS_API", message, arg);
   va_end(arg);

   if (error > 0)
      exit(error);
}
void main(){
Error(0,"Problem %s in file", "sometext");
}

}//extern "C"

问题是我的代码输出:'Problem |�;A.|�;A. in file'

__android_log_print(ANDROID_LOG_WARN, "HTS_API","Problem %s in file", "sometext");

正确的输出是:'Problem sometext in file'

我究竟做错了什么?

4

1 回答 1

10

__android_log_print不接受 ava_list作为参数。它接受可变参数列表。

看起来像是在他们添加的最新 NDK 中

int __android_log_vprint(int prio, const char *tag, const char *fmt, va_list ap);

这就是你想要的。以前,您必须通过 Error使用可变参数列表重新实现为宏或使用vsprintf在缓冲区中格式化错误消息然后说来解决此问题

__android_log_print(ANDROID_LOG_WARN, "HTS_API", "%s", buf);
于 2012-06-25T12:54:26.830 回答