How do I call std::min
when min
has already been defined as a macro?
The min macro compares two values and returns the smaller one. The data type can be any numeric data type, signed or unsigned. The data type of the arguments and the return value is the same.
std::min is defined in the header file <algorithm> and is used to find out the smallest of the number passed to it.
(std::min)(x,y)
The parentheses around min
prevent macro expansion. This works with all function macros.
On Windows, you need to define NOMINMAX
before including any windows headers, preferable at the beginning of precompiled header.
Use #undef min
in your code, after #include <>
directives.
#include <...> // bad header that defines `min` macro
#ifdef min
#undef min
#endif
// rest f code.
Addendum: If you need to keep the value of the min
macro afterwards, you can disable its definition temporarily using a non-portable solution on some compilers. For instance, Microsoft's C++ compiler has a push_macro
pragma that also seems to be supported by GCC.
You might be able to avoid the macro definition by:
#undef
#define NOMINMAX
or similar or avoiding including the offending header)If those options can't be used or you don't want to use them, you can always avoid invoking a function-like macro with an appropriate use of parens:
#include <algorithm>
#include <stdio.h>
#define min(x,y) (((x) < (y)) ? (x) : (y))
int main()
{
printf( "min is %d\n", (std::min)( 3, 5)); // note: the macro version of `min` is avoided
}
This is portable and has worked since the dark, early days of C.
I found a couple of other ways to do it:
Method 1:
using std::min;
min(a, b); // uses either the macro or the function (don't add side effects!)
Method 2:
#ifndef BOOST_PREVENT_MACRO_SUBSTITUTION
#define BOOST_PREVENT_MACRO_SUBSTITUTION
#endif
...
std::min BOOST_PREVENT_MACRO_SUBSTITUTION(a, b)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With