warning C4003 and errors C2589 and C2059 on: x = std::numeric_limitslt;intgt;::max();(警告 C4003 以及错误 C2589 和 C2059 在:x = std::numeric_limitsint::max();)
问题描述
此行在一个小型测试程序中正常工作,但在我想要的程序中,我收到以下编译器投诉:
This line works correctly in a small test program, but in the program for which I want it, I get the following compiler complaints:
#include <limits>
x = std::numeric_limits<int>::max();
c:...x.cpp(192) : warning C4003: not enough actual parameters for macro 'max'
c:...x.cpp(192) : error C2589: '(' : illegal token on right side of '::'
c:...x.cpp(192) : error C2059: syntax error : '::'
我得到了相同的结果:
#include <limits>
using namespace std;
x = numeric_limits<int>::max();
为什么将 max 视为宏 max(a,b);?
Why is it seeing max as the macro max(a,b); ?
推荐答案
当包含定义 min
或 max
宏的 Windows 标头时,通常会发生这种情况.如果您使用的是 Windows 标头,请将 #define NOMINMAX
放入您的代码中,或者使用等效的编译器开关进行构建(即,对于 Visual Studio,使用 /DNOMINMAX).
This commonly occurs when including a Windows header that defines a min
or max
macro. If you're using Windows headers, put #define NOMINMAX
in your code, or build with the equivalent compiler switch (i.e. use /DNOMINMAX for Visual Studio).
请注意,使用 NOMINMAX
构建会禁止在整个程序中使用宏.如果需要使用 min
或 max
操作,请使用 std::min()
或 std::max()
来自 标头.
Note that building with NOMINMAX
disables use of the macro in your entire program. If you need to use the min
or max
operations, use std::min()
or std::max()
from the <algorithm>
header.
这篇关于警告 C4003 以及错误 C2589 和 C2059 在:x = std::numeric_limits<int>::max();的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:警告 C4003 以及错误 C2589 和 C2059 在:x = std::numeric_limits<int>::max();


- 与 int by int 相比,为什么执行 float by float 矩阵乘法更快? 2021-01-01
- STL 中有 dereference_iterator 吗? 2022-01-01
- 一起使用 MPI 和 OpenCV 时出现分段错误 2022-01-01
- 从python回调到c++的选项 2022-11-16
- 使用/clr 时出现 LNK2022 错误 2022-01-01
- Stroustrup 的 Simple_window.h 2022-01-01
- 如何对自定义类的向量使用std::find()? 2022-11-07
- 近似搜索的工作原理 2021-01-01
- C++ 协变模板 2021-01-01
- 静态初始化顺序失败 2022-01-01