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

にデバッグ出力を追加できませんFunctionか?

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

第 1 の規則: マクロとそれが置き換える関数に別の名前を使用します。
2 番目のルール: gcc を使用している場合は、コード ブロックを括弧 ({ }) で囲んで、あたかも関数を呼び出せるようにします。printf("%f\n",sqrt(2.0));

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

于 2012-11-06T11:39:57.597 に答える
0

最初に2番目の関数を実装してから、マクロでコードをそれにリダイレクトする必要があります。バージョンでは、マクロを使用するすべての場所に関数を実装します:

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 に答える