Android中间层c语言log打印方法

本文介绍了在Android中,如何使用C代码通过两种方式打印日记:一是通过串口打印,利用log_to_kmsg函数将信息写入/dev/kmsg;二是通过logcat打印,需在Android.mk中添加liblog和libutils依赖,并调用__android_log_print函数。
摘要由CSDN通过智能技术生成

在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__))

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值