作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我构建了一个自定义日志记录函数,它接收“日志级别”和字符串。用户将指定与消息关联的日志级别(即错误、警告、跟踪等)。日志功能只会根据当前配置的日志级别将消息打印到控制台。
int global_log_level = INFO;
void logger(int msg_log_level, char * msg)
{
if(msg_log_level >= global_log_level )
{
printf("Log Level = %u: %s", msg_log_level, msg);
}
}
理想情况下,我想将格式化的字符串提供给这个函数。
logger(LOG_LEVEL_ERROR, "Error of %u occurred\n", error_code);
但是,通过添加此“包装”逻辑,我无法输入格式化的消息。相反,我必须将消息写入一个临时字符串,然后将其输入到函数中。
char temp[512];
sprintf("Error of %u occurred\n", error_code);
logger(LOG_LEVEL_ERROR, temp);
有没有办法实现记录器功能,这样我就不需要让用户自己创建一个临时字符串?
最佳答案
这是 question 15.5在 C FAQ list .
你要vprintf
,它可以让您编写自己的 printf
类函数logger
,但是您可以将实际的格式字符串和参数传递给 vprintf
做这项工作。诀窍是你需要构造一个特殊的va_arg
键入“指向”可变长度参数列表。它看起来像这样:
#include <stdarg.h>
int global_log_level = INFO;
void logger(int msg_log_level, char * msg, ...)
{
va_list argp;
va_start(argp, msg);
if(msg_log_level >= global_log_level )
{
printf("Log Level = %u: ", msg_log_level);
vprintf(msg, argp);
}
va_end(argp);
}
关于c - 如何在 C 中定义一个接受格式化输入字符串的函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68154231/
我是一名优秀的程序员,十分优秀!