gpt4 book ai didi

我可以为自定义日志记录功能启用格式警告吗?

转载 作者:太空宇宙 更新时间:2023-11-03 23:40:52 24 4
gpt4 key购买 nike

出于调试目的,我创建了一个自定义日志记录函数。出于所有实际目的,假设它是这样定义的:

void debugLog(const char * s, ...) {
va_list args;
va_start(args, s);
if(NULL!=logfp) {
vfprintf(logfp, s, args);
}
va_end(args);
}

问题是我的自定义函数跳过了格式警告。

如果我这样写,例如:

fprintf(logfp, "Received error: %d.\n");

我会收到这样的警告:

warning: format '%d' expects a matching 'int' argument [-Wformat]

但是如果我调用,我不会得到任何警告:

debugLog("Received error: %d.\n");

有没有办法为我的函数启用这样的警告?

也许我可以告诉 mingw-gcc 像对待 printf 一样对待 debugLog?或者这种警告是硬编码到编译器中的吗? (即:gcc 只是知道 *printf* 系列,但我们不能指望它知道我的函数)

最佳答案

至少对于 gcc,你可以使用 function attribute :

__attribute__((format(printf, 1, 2)))
void debugLog(const char * s, ...) {
...
}

关于我可以为自定义日志记录功能启用格式警告吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46368631/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com