#ifdef标志来区分gcc和g++编译器
#ifdef flag to tell difference between gcc and g++ compilers?
gcc将C程序编译为C,将C++程序编译为C++,因此需要C++中的"extern"C"声明。然而,g++将C程序编译为C++,将C++程序编译为C++,因此要求在C++中不得使用"extern"C"声明。
在没有任何输入的情况下检查标准标志,包括
g++ -E -dM - </dev/null
gcc -E -dM - </dev/null
给出相同的结果。
__GNUG__ is equivalent to testing (__GNUC__ && __cplusplus)
这将再次不会在C++源列表中区分gcc和g++。
有什么魔力
#ifndef __MAGIC_G++_INCLUDE_FLAG_BUT_NOT_GCC__
包装外部"C"{声明?谢谢。
编辑:我意识到这是一个相当深奥的案例。测试需要在编译器风格上进行,而不是在源代码口味上进行。在这两种情况下,测试都是在C++源代码列表中执行的(这就是为什么我提到GNUG是不充分的)。为了澄清,对于测试main.cpp:
#include <iostream>
int
main( int argc, char **argv )
{
#ifdef __cplusplus <<<< FIX THIS ONE
std::cout << "I was compiled using g++" << std::endl;
#else
std::cout << "I was compiled using gcc" << std::endl;
#endif
}
当使用任一编译时
g++ main.cpp
或
gcc main.cpp -lstdc++
在这两种情况下,它似乎都错误地将"I was compiled using++"作为输出。因此,在这种情况下,cplusplus似乎不是正确的标志。我错了吗?或者什么是正确的标志?
编辑2:谢谢,伙计们。这里有一个例子。大型遗留系统"Alpha"主要用C编写,有一点C++,并使用用C++编写的大型遗留源代码包"Charlie"。它使用g++系统进行编译和链接,并要求Charlie的头中没有外部的"C"定义,否则它拒绝链接。大型遗留系统"Bravo"大部分是用C编写的,有一点C++,也使用了用C++编写的相同遗留源代码包Charlie。它使用gcc系统进行编译和链接,并要求Charlie的标头中必须有外部的"C"定义,否则它将拒绝链接。新系统"Delta"、"Echo"answers"Foxtrot"也希望重用来自Charlie的部分源代码,编译器的使用是不确定的。正确的答案是用一劳永逸地破解Charlie的头部
#ifndef __MAGIC_G++_INCLUDE_FLAG_BUT_NOT_GCC__
extern "C" {
#endif
...
declarations of code
...
#ifndef __MAGIC_G++_INCLUDE_FLAG_BUT_NOT_GCC__
}
#endif
然后处理它。否则,总会出现链接问题。是的,当然,在这种特殊情况下,可以编译两组库,一组在C下,另一组在C++约定下,然后强制要求您使用这个特定的库进行这种特殊的链接。或者我可以想出两组标题。在这个例子中,这两种方式中的任何一种都是不雅的,并将在未来继续引发问题;还有其他情况。至于g++和gcc都在后台使用同一个编译器的评论,所以这可能无关紧要,遗憾的是,它确实重要。当不包含错误的"外部"C教条时,包作为一个整体拒绝链接。是的,还有其他方法可以解决一般问题,但这是一个简单的问题。要么这样的标志存在,要么它不存在,要么答案还不明确。我自己也不知道。
标准技术是检查是否定义了预处理器符号__cplusplus
:
#ifdef __cplusplus
extern "C" {
#endif
/* declarations here */
#ifdef __cplusplus
}
#endif
- C/C++编译器通常会删除重复的库吗
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- Win32编译器选项和内存分配
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- C++,我收到一个无法理解的编译器错误
- 在线编译器中的分段C++没有打印消息
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- C/C++预处理器是否可以检测一些编译器选项
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 我需要知道编译器如何在cpp中使用析构函数
- 编译器如何区分std::vector的构造函数
- CLANG 编译器 说:变量"PTR"可能未初始化
- 告诉c++编译器该参数没有别名
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么所有C++编译器都会崩溃或挂起此代码
- 编译器如何在使用SFINAE的函数和标准函数之间确定两者是否可行
- 我收到同义重复编译器错误。我应该如何修复"类型"X"的参数与类型"X"的参数不兼容?
- 为什么C++编译器没有检测到正确声明的类?