今天还是配置一个工程,遇到了这个问题,使用min时提示:输入正确的标识符。
看下面的代码:
导致这种问题的原因:宏定义产生了冲突。
解决方案一:
使用预处理器来屏蔽min:
项目属性 ——> C/C++ ——> 预处理器 ——> 预处理器定义 ——>加入NOMINMAX
这种方式可能导致其他问题,斟酌使用。
解决方案二:
解决两个名字空间宏定义产生的冲突
在C语言编程中,对一个比较大型的项目,用到的库会比较多,如果设计的稍有疏忽,便可能产生宏定义的冲突。项目中有一个例子就是发生在两个头文件都定义了min
/max
这个宏,并且两个宏定义不太一致,从而导致了整个工程无法编译。
解决该问题的方法是将该宏undefine,具体的做法是,
在紧邻include语句之后对有冲突的宏进行undefine。例如库liba.h和头文件 app_pub.h就有对ISSPACE (ch)的不同定义,如果同时使用这两个文件,就会产生宏定义的冲突,这时,可以将其一个undefine(一个前提是,不是两个头文件定义的宏都会用到):
#include “app_pub.h”
#ifdef ISSPACE
#undef ISSPACE
#endif
这样的方法是解决宏定义冲突的一个无奈之举。事实上,宏定义的作用域早就被人诟病,特别放在头文件中,被数次包含之后,在不经意间又被覆盖,然后又被重新使用,也许此时已经不是原来的意思了,而我们在使用时还不知道。
为此,有一个简单的原则可以减少宏定义的冲突,
那就是尽量不要将宏定义置于头文件当中,除非有一个非将其置于头文件不可的理由。
除此之外,还有一个策略 是,如果一个文件/库的某个函数不会被其他地方所使用,那么就不要将其置于头文件当中。