论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
IT评测·应用市场-qidao123.com
»
论坛
›
软件与程序人生
›
后端开发
›
.Net
›
easylogging++的那些事(二)宏定义
easylogging++的那些事(二)宏定义
罪恶克星
论坛元老
|
2022-11-23 21:14:28
|
显示全部楼层
|
阅读模式
楼主
主题
1010
|
帖子
1010
|
积分
3030
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
上一篇文章我们简要介绍了 easylogging++的
主要功能
。easylogging++中有很多特性是通过宏来控制的,今天我们就来聊聊这些宏:
debug 输出流宏定义
ELPP_INTERNAL_DEBUGGING_OUT_INFO(目前相当于 std:: cout)
ELPP_INTERNAL_DEBUGGING_OUT_ERROR(目前相当于 std:: cerr)
ELPP_INTERNAL_DEBUGGING_ENDL(目前相当于 std:: endl)
字符串包装宏 ELPP_INTERNAL_DEBUGGING_MSG(目前就是字符串本身)
断言宏
ELPP_DISABLE_ASSERT(禁用断言)
ELPP_DEBUG_ASSERT_FAILURE(断言条件失败时,程序停止在断言处不继续往下执行)
errno 错误输出宏 ELPP_INTERNAL_DEBUGGING_WRITE_PERROR
详细错误信息调试宏(会输出自定义错误信息加上 errno 错误信息 ELPP_INTERNAL_DEBUGGING_WRITE_PERROR)
ELPP_DEBUG_ERRORS 启用宏
ELPP_INTERNAL_ERROR 调试详细错误信息输出宏
INFO 调试日志宏 调试源码时输出内部的 INFO 日志信息
ELPP_DEBUG_INFO
ELPP_INTERNAL_INFO_LEVEL(默认最大 info 级别设为 9)
CRASH 堆栈日志宏(
仅仅支持 GCC
)
开启宏: ELPP_FEATURE_ALL 或者 ELPP_FEATURE_CRASH_LOG
STACKTRACE 宏: ELPP_STACKTRACE
杂项宏
ELPP_UNUSED 指示未使用的变量或者参数
ELPP_LOG_PERMS linux 文件权限宏
ELPP_AS_DLL ELPP_EXPORT_SYMBOLS windows dll 导入导出宏
STRTOK STRERROR STRCAT STRCPY 常见字符串库函数宏
ELPP_NO_SLEEP_FOR 当前平台是否支持 sleep 库函数
ELPP_UTC_DATETIME 当前时间函数宏(默认使用本地时间相关函数,定义后,使用 UTC 时间相关函数)
启用标准线程库宏
ELPP_FORCE_USE_STD_THREAD 强制使用标准库的线程接口(内部会测试系统信息是否支持)
异步日志宏 ELPP_EXPERIMENTAL_ASYNC
线程安全宏 ELPP_THREAD_SAFE 或 ELPP_EXPERIMENTAL_ASYNC
函数签名宏 ELPP_FUNC
可变参模板支持条件测试宏 ELPP_VARIADIC_TEMPLATES_SUPPORTED
日志启用相关宏
禁用全部日志
ELPP_DISABLE_LOGS(
日志输出的前提
)
单独禁用 DEBUG 日志 ELPP_DISABLE_DEBUG_LOGS
单独禁用 INFO 日志 ELPP_DISABLE_INFO_LOGS
单独禁用 WARNING 日志 ELPP_DISABLE_WARNING_LOGS
单独禁用 ERROR 日志 ELPP_DISABLE_ERROR_LOGS
单独禁用 FATAL 日志 ELPP_DISABLE_FATAL_LOGS
单独禁用 TRACE 日志 ELPP_DISABLE_TRACE_LOGS
单独禁用 VERBOSE 日志 ELPP_DISABLE_VERBOSE_LOGS
STL 相关容器日志直接输出支持相关宏
所有 STL 容器都需要: ELPP_STL_LOGGING
array 需要:ELPP_LOG_STD_ARRAY
unordered_set 需要:ELPP_LOG_UNORDERED_SET
QT 相关容器日志直接输出支持相关宏 ELPP_QT_LOGGING
BOOST 相关容器日志直接输出支持相关宏 ELPP_BOOST_LOGGING
WXWIDGETS 相关类日志直接输出支持相关宏 ELPP_WXWIDGETS_LOGGING
unicode 支持宏 ELPP_UNICODE
默认日志记录器 id 宏(不指定时为 default) ELPP_DEFAULT_LOGGER
性能跟踪宏:ELPP_FEATURE_PERFORMANCE_TRACKING
默认性能跟踪日志记录器 id 宏(不指定时为 performance) ELPP_DEFAULT_PERFORMANCE_LOGGER
全部特性开启宏(主要用于性能跟踪和 crash 堆栈记录) ELPP_FEATURE_ALL
syslog 日志开启宏(需要系统支持 syslog 日志, 默认 syslog 的日志记录器 id 为 syslog) ELPP_SYSLOG
MAKE_LOGGABLE 用于兼容无法修改源码的第三方类型也能直接进行日志输出
性能跟踪宏
TIMED_SCOPE_IF
TIMED_SCOPE
TIMED_BLOCK
TIMED_FUNC_IF
TIMED_FUNC
PERFORMANCE_CHECKPOINT
PERFORMANCE_CHECKPOINT_WITH_ID
指定文件指定行计数器(用于条件记录日志)
ELPP_COUNTER
ELPP_COUNTER_POS
写日志相关宏(easylogging++的哪些事(一):
功能介绍
中仔细介绍过)
宏技巧:
获取可变参的数量: el_resolveVALength(
目前源码当中最多只能获取的可变参数量限制在 10 个
)
easylogging++当中的宏就介绍到这里,下一篇文章将开始介绍 easylogging++的总体框架。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复
使用道具
举报
0 个回复
正序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
发新帖
回复
罪恶克星
论坛元老
这个人很懒什么都没写!
楼主热帖
2. 函数
从Android开发的角度比较MVC,MVP,MVVM ...
京东张政:内容理解在广告场景下的实践 ...
KAFKA EAGLE 监控MRS kafka之操作实践 ...
关键字和标识符
React技术栈 --》plugin与JSX语法使用 ...
dotnet 6 为什么网络请求不跟随系统网 ...
HCIA学习笔记十一:ARP地址解析协议 ...
数字图像增强的一般方法
Vue前后台数据交互实例演示,使用axios ...
标签云
AI
运维
CIO
存储
服务器
浏览过的版块
SQL-Server
程序人生
Mysql
云原生
Nosql
网络安全
IOS
容器及微服务
物联网
快速回复
返回顶部
返回列表