在Android中,中间层的C代码要打印出日记,有如下两种方法
1.往串口里打印数据
调用log_to_kmsg函数,然后adb shell dmesg查看日记或者电脑接串口来查看,如
log_to_kmsg("the num is %d\n",ret);
#include <stdio.h>
#include <string.h>
#include <fcntl.h>
#include <stdarg.h>
static void log_to_kmsg(char* format,...)
{
va_list args;
int fd;
char string[1000];
va_start(args,format);
vsprintf(string,format,args);
va_end(args);
fd = open("/dev/kmsg",O_RDWR);
if(fd == -1)
{
return;
}
write(fd,string,strlen(string)+1);
close(fd);
}
2.往logcat里打印数据
在Android.mk加入
LOCAL_SHARED_LIBRARIES := liblog libutils
LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog
并调用
#include <android/log.h>
#define LOG_TAG "MSG"
#define LOGD(...) ((void)__android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__))
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__))
#define LOGW(...) ((void)__android_log_print(ANDROID_LOG_WARN, LOG_TAG, __VA_ARGS__))
#define LOGE(...) ((void)__android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__))