- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在处理定义如下的日志宏:
#define LOGD(...) rtt_printf(TERMINAL_DEBUG, ##__VA_ARGS__)
#define LOGV(...) rtt_printf(TERMINAL_NORMAL, ##__VA_ARGS__)
一切都很好,但我想禁用发布版本的调试日志。但是由于我使用的是 -Werror
和 -Wall
我在定义 LOGD 而没有 rtt_printf() 时只会出错>。除了在 LOG 调用之前显式声明 (void)var; 以抑制未使用的参数警告之外,还有什么方法(更动态的方法)吗?
最佳答案
你可能有
#ifdef NDEBUG
#define LOGD(...) do {} while(0)
#else
#define LOGD(...) do {rtt_printf(TERMINAL_DEBUG, ##__VA_ARGS__); \
} while(0)
#endif
遵循 NDEBUG
上的惯例被 assert(3) 使用
如果你想使用参数让你的编译器满意并让它检查参数,你可以尝试(在 NDEBUG
的情况下)
#define LOGD(...) do { if (false) printf(__VA_ARGS__); }while(0)
所以 optimizing compiler不会发出任何调用 printf
(如果使用 GCC ,请务必将 -Wall -O2
至少传递给 g++
)
顺便说一句,我会建议(对于没有 NDEBUG
的调试情况):
#define LOGD(Fmt,...) do { rtt_printf(TERMINAL_DEBUG, "%s:%d " Fmt "\n", \
__FILE__, __LINE__, ##_VA_ARGS); } while(0)
然后使用 LOGD("x=%d", x)
在你的代码中。这将显示源代码行位置。
最后,在真正的 C++11 中,您最好使用来自 <ostream>
的输出流和代码(用于调试案例):
#define LOGOUTD(Out) do {std::clog << __FILE__ << ":" << __LINE__ \
<< " " << Out << std::endl;}while(0)
然后使用 LOGOUTD("x="<<x)
.然后,如果您定义了合适的 std::ostream& operator << (std::ostream&, const Foo&)
为你的类(class)Foo
, 你可以有 x
是它的一个实例。
附言。参见 this有关 do{
的解释... }while(0)
在宏中。
关于c++ - 如何声明省略号定义的 va_list 未使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37960305/
尝试编译此代码时 #include void bar_ptr(int n, va_list *pvl) { // do va_arg stuff here } void bar(int n,
假设我有一个函数,它接受可变参数 (...) 或从另一个此类函数传递的 va_list 。主要逻辑在这个函数本身(我们称之为 f1),但我想让它将 va_list 传递给另一个函数(我们称之为 f2)
看似简单的问题,但一直未能在 SO 或 C 标准中找到答案。问题是 va_list 是否必须是 C 中函数的最后一个参数(当然,假设该函数将 va_list 作为参数)。 例如,这样安全吗? int
我正在尝试打印字符串类型的参数变量,但我一直卡在这上面 想法 尝试使用 _Str[i] 作为 while 循环内的表达式在 srting 内部移动,一旦 _Str[i] == '\0' 返回 (-1
下面的 max 函数应该返回 5,但它返回的是 4294967294。我怀疑奇怪的行为是由变量转换引起的,但无法弄清楚。有人能检测出故障吗? 系统:Windows 7(64位),mingw64 #in
在 Fedora 11 上编译一些工作代码时,我收到此错误: /usr/include/c++/4.4.1/cstdarg:56: error: ‘::va_list’ has not been de
全部, 我想控制 va_list 中的传递参数的数量。 va_list args; va_start(args, fmts); vfprintf(stdout, fmts, args)
我有一个很好的 C++ 函数,它通过 va_list + va_start + va_arg 支持多个参数。但我必须将我的项目转换为 C。转换后,这个 va_list 构造被编译器拒绝(多个错误)。有
我已经编写了这段代码,但我不确定它是否可以。 size_t sendHeaders(int fd, int seconds, const char* header1, ...) { size_
我无法找到我的“问题”的答案。 我创建了一个函数,它接受不同数量的整数('findMinVal(int x, ...)')并返回所有调用中的最小数字。现在我的程序直接通过代码获取参数: int mai
我一直在追踪一个问题,并将范围缩小到这个框架: #include #include #include #include #include #include typedef struct _
我有一个主要更新,我在通话前进行访问控制。我想在我的代码中使用一个地方来调用任何紧急函数。 我有一个结构 ACTION: { FUNC_PROTOTYPE pfnAction; uns
我目前有 2 个函数重载: void log(const char* format, ...); void log(const string& message); 我希望在这个调用的情况下:log("
在 case 's' 下,我得到一个坏指针 (0xcccccccc) 异常: string Logger::format(const char *str, va_list args) { os
#include #include void s(const char* param, ...) { va_list arguments; va_start (arguments,
我试着写一个这样的函数: int solve(double* x, double xA, double xB, double zeps, double funct(double x
我有这样的代码 #include "atlstr.h" void DisplayMessage(CString pszFormat, ...) { CString str; va_l
我正尝试在 C++ 中为一个项目实现一种反射形式。这个想法是,您将带有标签的类作为一种模板注册到映射中,然后调用共享基类的 cloneNew 方法来实际创建您想要的对象。但是,当我尝试使用 va_li
我已经(简单地)编写了这段代码。但它需要两次修复才能确定。 size_t send_header(int fd, int seconds, const char* header1, ...) {
我有一个用于微 Controller 的以太网库(用于 lpc2478 的 keil rl-tcpnet)。库以这种方式在调试输出函数中使用 va_list(指向 stdarg.h 中定义的 arg
我是一名优秀的程序员,十分优秀!