Search code examples
c++cconstantspreprocessorcalculation

do constant calculations in #define consume resources?


as far as I'm concerned, constants and definitions in c/c++ do not consume memory and other resources, but that is a different story when we use definitions as macros and put some calculations inside it. take a look at the code:

#include "math.h"
#define a 12.2
#define b 5.8
#define c a*b
#define d sqrt(c)

When we use the variable 'd' in our code, does it spend time for CPU to calculate the SQRT and add operations or this values are calculated in compiler and just replaced in the code? If it is calculated by CPU, is there anyway to be calculated beforehand in preprocessor and assigned as a constant here?


Solution

  • as far as I'm concerned, constants and definitions in c/c++ do not consume memory and other resources,

    It depends on what you mean by that. Constants appearing in expressions that potentially are evaluated at runtime have to be represented in the program somehow. Under most circumstances, that will take some space.

    Even (in C++) a constexpr can be evaluated at runtime, even though implementations can and probably do evaluate them at compile time.

    but that is a different story when we use definitions as macros and put some calculations inside it.

    Yes, it is different, because macros are not constants in any applicable sense of that term.

    take a look at the code:

    #include "math.h"
    #define a 12.2
    #define b 5.8
    #define c a*b
    #define d sqrt(c)
    

    When we use the variable 'd' in our code,

    d is not a variable. It is a macro. Wherever it appears within the scope of those macro definitions, it is exactly equivalent to the expression sqrt(12.2*5.8) appearing at that point.

    does it spend time for CPU to calculate the SQRT and add operations or this values are calculated in compiler and just replaced in the code?

    Either could happen. It depends on your compiler, probably on compilation options, and possibly on other code in the translation unit. Pre-computation is more likely at higher optimization levels.

    If it is calculated by CPU, is there anyway to be calculated beforehand in preprocessor and assigned as a constant here?

    Such a calculation is not part of the semantics of the preprocessor per se. To the somewhat artificial extent that we draw a distinction between preprocessor and compiler in modern C and C++ implementations, if a precomputation is performed then it will be performed by the compiler, not the preprocessor.

    The C and C++ languages do not define a mechanism to force such evaluations to be performed at compile time, but you can make it more likely by increasing the compiler's optimization level. Or in C++, there is probably a way to use a template to wrap the expression in a constexpr function computing its value, which would make it very likely to be computed at compile time.

    But if a constant is what you want, then you always have the option of pre-computing it manually, and defining the macro to expand to an actual constant.