打印
[应用相关]

【开源】C/C++ 日志库 EasyLogger 新增彩色日志、异步输出等

[复制链接]
2298|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
armink|  楼主 | 2016-11-14 20:46 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
EasyLogger 是一款超轻量级(ROM<1.6K, RAM<0.3K)、高性能的 C/C++ 日志库,非常适合对资源敏感的软件项目,例如: IoT 产品、可穿戴设备、智能家居等等。 EasyLogger 功能简单,上手速度快,更多实用功能支持以插件形式进行动态扩展。
主要特性
  • 支持用户自定义输出方式(例如:终端、文件、数据库、串口、485、Flash...);
  • 日志内容可包含级别、时间戳、线程信息、进程信息等;
  • 日志输出被设计为线程安全的方式,并支持 异步输出缓冲输出 模式;
  • 支持多种操作系统(RT-Thread、UCOS、Linux、Windows...),也支持裸机平台;
  • 日志支持 RAW格式 ;
  • 支持按 标签 、 级别 、 关键词 进行动态过滤;
  • 各级别日志支持不同颜色显示
  • 扩展性强,支持以插件形式扩展新功能。

已提供以下平台 Demo

\demo\non_os\stm32f10x\
stm32f10x裸机的 demo
\demo\os\linux\
linux平台 demo
\demo\os\windows\
windows平台 demo
\demo\os\rt-thread\stm32f10x\
stm32f10x基于RT-Thread的demo(包含Flash插件demo)

本次更新版本号 V1.11.13,主要发布以下重要功能


1、新增彩色日志
所有级别日志可独立设置颜色,错误信息更加明显,日志更加赏心悦目,进一步提升调试效率。详细使用方法,请参照说明文档(/doc/zh/port/kernel.md)。Linux Demo 里已经默认开启了此功能,大致效果如下,欢迎试用


2、新增异步输出模式(非阻塞输出模式)
之前的版本默认为阻塞的同步输出模式,即用户线程输出日志时,日志必须完全输出到输出介质(串口、网络、文件等)上,输出过程才会退回。
这样会影响应用软件执行时间及执行效率。开启异步输出模式后,后台有专门的日志线程负责完成日志输出功能,应用程序输出日志时,底层只将日志拷贝至缓冲区后,随即退出日志输出方法。

异步输出默认使用 POSIX pthread 实现,对于 Windows 、Liunx 、RT-Thread 及其他支持 POSIX pthread 的用户,只需开启异步输出相关配置,即可开启此功能。
对于缺少 pthread 支持的平台,例如:ucos ,也可以参考 elog_async.c 中关于异步输出线程的实现方式,自己动手实现。
PS:Linux  Demo 中已开启 pthread 异步输出模式,RT-Thread Demo 已使用其线程相关 API 实现异步输出模式。

3、新增缓冲输出模式
开启缓冲输出模式后,如果缓冲区不满,用户线程在进行日志输出时,无需等待日志彻底输出完成,即可直接返回。
但当日志缓冲区满以后,将会占用当前用户线程,自动将缓冲区中的日志全部输出干净。
同时用户也可以在其他非用户线程,通过定时等机制使用 `void elog_flush(void)` 将缓冲区中的日志输出干净。

下载方式
最新版请关注 GitHub(选中地址右键->转到):github.com/armink/EasyLogger
本坛下载(修改后缀为 .7z ): EasyLogger-V1.11.13.tar (1.52 MB)




发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

3

主题

21

帖子

1

粉丝