printf 模仿slf4j 的log.xxx效果

printf 模仿slf4j 的log.xxx效果

    • 简介
    • 期待的效果
    • 颜色
    • 遇到的问题
    • 实际的效果
    • 代码实现
    • 使用
    • 效果图

简介

突然想玩一玩,能不能用printf实现slf4j里 的log.xxx 的效果。

性能是完全不考虑的,只要功能可用就好。

期待的效果

类似:info("这是第{}条日志",index);

颜色

一个好的日志打印,应当有对应的颜色。直接抄springboot 对应日志的默认配色。

遇到的问题

尝试使用c中的可变参数去实现,但是发现,可变是可变了,却不知道数据的类型。
而不知道数据的类型,printf 就没法打印。如果强行当做%s打印,那么解析铁定出错,因为它要找\0作为结束标签。

目前暂时没有找到办法,那就只能保留这个输出格式符,但是不要前面的%号。
比较,从键盘上看% 离的还挺远,不好找,可读性也比较差。

实际的效果

类似:info("这是第{d}条日志",index);

代码实现

util.h

#pragma once
void trace(const char * str, ...);
void debug(const char * str, ...);
void info(const char * str, ...);
void warn(const char * str, ...);
void error(const char * str, ...);

util.c

#include"util.h"
#include<stdio.h>
#include<stdarg.h>
#include<string.h>
#define ANSI_COLOR_RED     "\033[31m"
#define ANSI_COLOR_GREEN   "\033[32m"
#define ANSI_COLOR_YELLOW  "\033[33m"
#define ANSI_COLOR_BLUE    "\033[34m"
#define ANSI_COLOR_MAGENTA "\033[35m"
#define ANSI_COLOR_CYAN    "\033[36m"
#define ANSI_COLOR_RESET  "\033[0m"void resolveAndPrint(va_list args, const char * str);
/*带颜色的打印
*/
void printC(const char * color, const char * tag) {printf("%s%s%s", color, tag, ANSI_COLOR_RESET);}void trace(const char * str, ...) {printC(ANSI_COLOR_YELLOW, "    [ TRACE ]:  ");//声明va_list args;//初始化	va_start(args, str);//执行遍历resolveAndPrint(args, str);va_end(args);
}
void debug(const char * str, ...) {printC(ANSI_COLOR_YELLOW, "    [ DEEBUG ]:  ");//声明va_list args;//初始化	va_start(args, str);//执行遍历resolveAndPrint(args, str);//清理va_end(args);}
void info(const char * str, ...) {printC(ANSI_COLOR_CYAN, "    [ INFO ]:  ");//声明va_list args;//初始化	va_start(args, str);//执行遍历resolveAndPrint(args, str);//清理va_end(args);}
void warn(const char * str, ...) {printC(ANSI_COLOR_MAGENTA, "    [ WARN ]:  ");//声明va_list args;//初始化	va_start(args, str);//执行遍历resolveAndPrint(args, str);//清理va_end(args);}void error(const char * str, ...) {printC(ANSI_COLOR_RED, "    [ ERROR ]:  ");//声明va_list args;//初始化	va_start(args, str);//执行遍历resolveAndPrint(args, str);//清理va_end(args);
}void resolveAndPrint(va_list args, const char * str) {char * ch = str;char lastCh = 0;while (*ch != '\0'){if ((lastCh != '\\') && (*ch == '{' || *ch == '}')){lastCh = *ch;ch++;//跳过即可continue;}//匹配到类似 \\{ \\t \\n 这种,就直接输出原意 if ((lastCh == '\\')){printf("%c", *ch);lastCh = *ch;ch++;continue;}if (*ch == '\\'){lastCh = *ch;ch++;continue;}if (lastCh == '{') {//开始匹配参数了char symbol = *ch;//printf("symbol=%c \n", symbol);switch (symbol){case 's':printf("%s", va_arg(args, char *));break;case 'c':printf("%c", va_arg(args, char));break;case 'd':printf("%d", va_arg(args, int));break;case 'f':printf("%.2f", va_arg(args, double));break;default:printf("%c", symbol);break;}}else{printf("%c", *ch);}lastCh = *ch;ch++;}printf("\n");}

使用

main.c

#include<stdio.h>
#include"util.h"int main() {trace("小明今年{d}岁了 \\{\\} {s}给他祝贺,送了字母{c},体重{f}", 3,"小红",'B',57.3);debug("hhhh");info("hhhh");warn("hhhh");error("hhhh");return 0;
}

效果图

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/15153.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ffmpeg-webrtc(metartc)给ffmpeg添加webrtc协议

这个是使用metrtc的库为ffmpeg添加webrtc传输协议&#xff0c;目前国内还有一个这样的开源项目&#xff0c;是杨成立大佬&#xff0c;大师兄他们在做&#xff0c;不过wili页面维护的不好&#xff0c;新手不知道如何使用&#xff0c;我专门对它做过介绍&#xff0c;另一篇博文&a…

不同类型水表计量技术的优缺点

1.单流束水表 1.1优点 (1)耐受悬浮固体。适用于硬水或悬浮颗粒物。 (2)多样性&#xff0c;可用性&#xff0c;容易找到需要的合适的表型。 (3)技术可靠&#xff0c;已使用了数十年。 (4)体积小&#xff0c;可以安装在狭小的空间里。 (5)13mm、15mm、20mm水表可能是市面…

CTFHUB技能树——SSRF(二)

目录 上传文件 ​FastCGI协议 Redis协议 上传文件 题目描述&#xff1a;这次需要上传一个文件到flag.php了.祝你好运 index.php与上题一样&#xff0c;使用POST请求的方法向flag.php传递参数 //flag.php页面源码 <?phperror_reporting(0);if($_SERVER["REMOTE_ADDR&…

C语言:有两个磁盘文件A和B,各存放一行字母,要求把这两个文件中的信息合并(按字母顺序排列),输出到一个新文件C中

int main() {int i, j 0;char arr_pfa[100], arr_pfb[100];FILE* pfa fopen("A.txt", "r");//自己事先创建 我这里A存放的是helloif (pfa NULL){perror("error:");return 1;}fgets(arr_pfa, 100, pfa);fclose(pfa);FILE* pfb fopen("B.…

【数据结构】神奇的二叉树

文章目录 前言1. 树形结构1.1 什么是树1.2 名词概念1.3 树的表现形式 2. 二叉树2.1 概念2.2 两种特殊的二叉树2.3 二叉树的性质 3. 二叉树的存储结构3.1 顺序存储3.2 链式存储 4. 二叉树的遍历4.1 前序遍历4.2 中序遍历4.3 后序遍历4.4 层序遍历 5. 遍历的代码实现5.1 递归实现…

PTT票据传递攻击

一. PTT票据传递攻击原理 1.PTT介绍 PTT(Pass The Ticket)&#xff0c;中文叫票据传递攻击&#xff0c;PTT 攻击只能用于kerberos认证中,NTLM认证中没有&#xff0c; PTT是通过票据进行认证的。 进行票据传递&#xff0c;不需要提权&#xff0c;域用户或者system用户就可以 …

【图书推荐】《Vue.js 3.x+Element Plus从入门到精通(视频教学版)》

本书用处 内容简介 本书通过对Vue.js&#xff08;简称Vue&#xff09;的示例和综合案例的介绍与演练&#xff0c;使读者快速掌握Vue.js 3.x框架的用法&#xff0c;提高Web前端的实战开发能力。本书配套示例源码、PPT课件、教学大纲、教案、同步教学视频、习题及答案、其他资源…

HTML+CSS 响应式导航栏

效果演示 Code <div class="navbar"><input type="checkbox"><span></span><span></span><ul><li><a href="#">点赞</a></li><li><a href="#">关注&…

SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?

尼恩&#xff1a;LLM大模型学习圣经PDF的起源 在40岁老架构师 尼恩的读者交流群(50)中&#xff0c;经常性的指导小伙伴们改造简历。 经过尼恩的改造之后&#xff0c;很多小伙伴拿到了一线互联网企业如得物、阿里、滴滴、极兔、有赞、希音、百度、网易、美团的面试机会&#x…

【数据结构】数据结构中的隐藏玩法——栈与队列

前言&#xff1a; 哈喽大家好&#xff0c;我是野生的编程萌新&#xff0c;首先感谢大家的观看。数据结构的学习者大多有这样的想法&#xff1a;数据结构很重要&#xff0c;一定要学好&#xff0c;但数据结构比较抽象&#xff0c;有些算法理解起来很困难&#xff0c;学的很累。我…

前端基于word模板导出word文档

项目环境 vue2 js vue-cli等 依赖包都可以在npm官网找到对应文档 npm官网(英文) 1、依赖 安装依赖 docxtemplater npm i docxtemplaterfile-saver npm i file-saverjszip-utils npm i jszip-utilsjszip npm i jszip在对应页面或模块中引入依赖 import Docxtemplater …

QQ个性网空间日志网站模板源码

QQ个性网空间日志网站模板源码自带后台登录设置&#xff0c;适用于博客、文章、资讯、其他类网站内容使用。模板自带eyoucms内核&#xff0c;原创设计、手工书写DIVCSS&#xff0c;完美兼容IE7、Firefox、Chrome、360浏览器等;主流浏览器;结构容易优化;多终端均可正常预览。由于…

力扣刷题---2206. 将数组划分成相等数对【简单】

题目描述&#x1f357; 给你一个整数数组 nums &#xff0c;它包含 2 * n 个整数。 你需要将 nums 划分成 n 个数对&#xff0c;满足&#xff1a; 每个元素 只属于一个 数对。 同一数对中的元素 相等 。 如果可以将 nums 划分成 n 个数对&#xff0c;请你返回 true &#xf…

力扣刷题---3146. 两个字符串的排列差

题目描述 给你两个字符串 s 和 t&#xff0c;每个字符串中的字符都不重复&#xff0c;且 t 是 s 的一个排列。 排列差 定义为 s 和 t 中每个字符在两个字符串中位置的绝对差值之和。 返回 s 和 t 之间的 排列差 。 示例 1&#xff1a; 输入&#xff1a;s “abc”, t “b…

运用HTML、CSS设计Web网页——“西式甜品网”图例及代码

目录 一、效果展示图 二、设计分析 1.整体效果分析 2.头部header模块效果分析 3.导航及banner模块效果分析 4.分类classify模块效果分析 5.产品展示show模块效果分析 6.版权banquan模块效果分析 三、HTML、CSS代码分模块展示 1. 头部header模块代码 2.导航及bann…

【SpringCloud】Spring Cloud基本介绍

目录 回顾架构分类单体架构分布式架构微服务架构什么是微服务优点缺点微服务的架构特征&#xff1a;微服务架构面临的挑战技术挑战微服架构的设计原则微服务概念提供者(Provider)消费者(Consumer)RPC和Restful集群分布式 总结 服务拆分和远程调用服务拆分原则服务拆分示例 思考…

http项目改为/支持https的方案、无需修改后台代码

背景描述&#xff1a;原来的项目前后台都是http&#xff0c;现在某个服务要求前台必须使用https&#xff1b; 方案1&#xff1a;前台部署在https里&#xff0c;后面代码修改&#xff1b;但是微服务架构&#xff0c;后台工作量太大&#xff1b; 方案2&#xff1a;前台部署在ht…

Pytorch-08 实战:手写数字识别

手写数字识别项目在机器学习中经常被用作入门练习&#xff0c;因为它相对简单&#xff0c;但又涵盖了许多基本的概念。这个项目可以视为机器学习中的 “Hello World”&#xff0c;因为它涉及到数据收集、特征提取、模型选择、训练和评估等机器学习中的基本步骤&#xff0c;所以…

vue 打印、自定义打印、页面打印、隐藏页眉页脚

花了一天时间搞了个打印功能&#xff0c;现则将整体实现过程进行整理分享。先来看看效果图&#xff1a; 1、页面展示为&#xff1a; 2、重组页面打印格式为&#xff1a;这里重组页面的原因是客户要求为一行两列打印 &#xff01;内容过于多的行则独占一行显示完整。 整体实现&…

区块链论文总结速读--CCF A会议 USENIX Security 2024 共7篇 附pdf下载

Conference&#xff1a;33rd USENIX Security Symposium CCF level&#xff1a;CCF A Categories&#xff1a;网络与信息安全 Year&#xff1a;2024 Num&#xff1a;7 1 Title: Practical Security Analysis of Zero-Knowledge Proof Circuits 零知识证明电路的实用安全…