2

我们的 C++ 代码中有一个现有的函数实现:

void Function(int param)
{
    printf("In Function\n");
}

int main()
{
    Function(10);
    return 0;
}

我希望将其更改为调用另一个函数(通过宏声明的帮助),该函数将接受 FILELINE等附加参数(用于调试目的),然后调用实际函数:

#define Function(param) Function_debug(param, __FILE__,  __FUNCTION__,  __LINE__) \
{\
    printf("In Function_debug [%s] [%s] [%d]\n", file, func, line); \
    Function(param);\
}

但是下面的代码:

#include <stdio.h>

#define Function(param) Function_debug(param, __FILE__,  __FUNCTION__,  __LINE__) \
{\
    printf("In Function_debug [%s] [%s] [%d]\n", file, func, line); \
    Function(param);\
}

void Function(int param)
{
    printf("In Function\n");
}

int main()
{
    Function(10);
    return 0;
}

翻译为:

void Function_debug(int param, "temp.cpp", __FUNCTION__, 9) { printf("In Function_debug [%s] [%s] [%d]\n", file, func, line); Function(int param);}
{
    printf("In Function\n");
}

int main()
{
    Function_debug(10, "temp.cpp", __FUNCTION__, 16) { printf("In Function_debug [%s] [%s] [%d]\n", file, func, line); Function(10);};
    return 0;
}

这会产生编译错误。

请指导我如何实现目标?

4

4 回答 4

6

通常你会做这样的事情:

#if DEBUG
#define FUNCTION(param) Function_debug(param, __FILE__,  __FUNCTION__,  __LINE__)
#else
#define FUNCTION(param) Function(param)
#endif

void Function(int param)
{
    printf("In Function\n");
}

void Function_debug(int param, const char * file,  const char * func,  int line)
{
    printf("In Function_debug [%s] [%s] [%d]\n", file, func, line); \
    Function(param);
}

int main()
{
    FUNCTION(10);
    return 0;
}
于 2012-11-06T11:39:20.897 回答
0

第一条规则:为您的宏和它替换的函数使用不同的名称。
第二条规则:如果使用 gcc,请将代码块包装在括号 ({ }) 中,以使您的函数可以像printf("%f\n",sqrt(2.0));

#define Function(a) ({ printf("Debug stuff\n"); orig_function(a);})

于 2012-11-06T11:39:57.597 回答
0

您应该首先实现第二个函数,然后在您的宏中将您的代码重定向到它,在您的版本中,您在任何使用宏的地方实现该函数:

void function( int param )
{
    // do something interesting here
}
void function_debug( int param, char const* fileName, unsigned line, char const* fn)
{
    // debug position here
    function( param );
}

#ifndef NDEBUG
#    define Function( param )    function_debug( param, __FILE__, __LINE__, __FUNCION__ )
#else
#    define Function( param )    function( param )
#endif
于 2012-11-06T11:42:08.453 回答
0

您不能将调试打印添加到Function吗?

void Function(int param)
{
    #ifdef DEBUG
    //debug stuff
    #endif
    printf("In Function\n");
}
于 2012-11-06T11:45:20.463 回答