qnx log写入文件 简单实现

qnx log写入文件 简单实现

c 复制代码
#ifndef __COMMON_LOG__
#define __COMMON_LOG__

#include "fcntl.h"
#include "pthread.h"
#include "stdarg.h"
#include "unistd.h"
#include <stdio.h>
#include <string.h>

//#define _LOG_FILE_NAME "/tmp/easy.log"
#define _LOG_FILE_NAME "easy.log"

#if defined _LOG_FILE_NAME

void __file_log_com(char *log_str, ...);
#define __file__                                                                                                       \
    ({                                                                                                                 \
        char *_rs = strrchr((char*)__FILE__, '/');                                                                            \
        _rs ? (_rs + 1) : __FILE__;                                                                                    \
    })
#define _COM_FILE_PARSE(lgType, prefix, fmt, args...)                                                                  \
    do {                                                                                                               \
        __file_log_com("[%s][%s:%s:%d][%s]" fmt, lgType, __file__, __func__, __LINE__, prefix, ##args);                \
    } while (0)

#define ts_log_info(dev, fmt, args...) _COM_FILE_PARSE("info", dev, fmt, ##args)
#define ts_log_err(dev, fmt, args...) _COM_FILE_PARSE("error", dev, fmt, ##args)
#define ts_log_warn(dev, fmt, args...) _COM_FILE_PARSE("warning", dev, fmt, ##args)
#define ts_log_dbg(dev, fmt, args...) _COM_FILE_PARSE("debug", dev, fmt, ##args)

#else

#define ts_log_info(dev, fmt, args...) 
#define ts_log_err(dev, fmt, args...)  
#define ts_log_warn(dev, fmt, args...) 
#define ts_log_dbg(dev, fmt, args...)  

#endif

static pthread_mutex_t _log_mutex;
static FILE *_log_fp = NULL;


// qnx 简单log写入文件 实现
void __file_log_com(char *log_str, ...) {
    va_list arg;

    if (NULL != _log_fp) {
        pthread_mutex_lock(&_log_mutex);
        va_start(arg, log_str);
        (void)vfprintf(_log_fp, log_str, arg);
        va_end(arg);
        //(void)fprintf(___fp, " \n");
        //(void)fclose(fp);
        fflush(_log_fp);
        pthread_mutex_unlock(&_log_mutex);
    }
}

void com_file_log_init(char *filename) {
    _log_fp = fopen(filename, "w");
    if (!_log_fp)
        return perror(__func__);

    pthread_mutex_init(&_log_mutex, NULL);
}

int main() {
    printf( "hello\n");
    com_file_log_init(_LOG_FILE_NAME);
    char* dev_name = (char*)"E800";
    ts_log_info(dev_name, "hello world");
    // __file_log_com("%s,%s", dev_name, "e800");
    printf( "finish\n");
    return 0;
}

#endif

运行结果:

hello

finish

写入文件样子:

相关推荐
武子康1 小时前
Java-171 Neo4j 备份与恢复 + 预热与执行计划实战
java·开发语言·数据库·性能优化·系统架构·nosql·neo4j
晚风吹长发2 小时前
二分查找算法+题目详解
c++·算法·二分查找
怪兽20142 小时前
fastjson在kotlin不使用kotlin-reflect库怎么使用?
android·开发语言·kotlin
ClearLiang2 小时前
Kotlin-协程的挂起与恢复
开发语言·kotlin
彭同学学习日志2 小时前
Kotlin Fragment 按钮跳转报错解决:Unresolved reference ‘floatingActionButton‘
android·开发语言·kotlin
海域云赵从友2 小时前
破解跨境数据传输瓶颈:中国德国高速跨境组网专线与本地化 IP 的协同策略
开发语言·php
咚咚王者2 小时前
人工智能之编程进阶 Python高级:第九章 爬虫类模块
开发语言·python
罗义凯3 小时前
其中包含了三种排序算法的注释版本(冒泡排序、选择排序、插入排序),但当前只实现了数组的输入和输出功能。
数据结构·c++·算法
深蓝海拓3 小时前
使matplot显示支持中文和负号
开发语言·python
春蕾夏荷_7282977254 小时前
c++ easylogging 使用示例
c++·log·easylogging