gpt4 book ai didi

c++ - 关于使用#define 有条件地排除主函数时的 C++ 预处理器

转载 作者:太空宇宙 更新时间:2023-11-04 15:27:56 25 4
gpt4 key购买 nike

情况是这样的:我有三个文件,Test1.cpp 和 Test2.cpp。 Test1.cpp 可以按原样编译成独立的应用程序。 Test1.cpp 还包含一些我想在 Test2.cpp 中重复使用的函数。我正在使用#ifndef#endif block 有条件地排除Test1.cpp 的主函数,这样当我编译Test2.cpp 时,Test2.cpp 中的主函数将能够调用Test1.cpp 中定义的函数。示例代码:

--------------------------------------------
//File: Test1.h
#include <iostream>
void do_something();
--------------------------------------------
//File: Test1.cpp
#include "Test1.h"
void do_something();
{
std::cout<<"Done"<<std::endl;
}
#ifndef FN_MAIN
int main()
{
do_something();
return 0;
}
#endif
--------------------------------------
//File: Test2.cpp
#define FN_MAIN
#include "Test1.h"
int main()
{
do_something();
return 0;
}
--------------------------------------

用 Test1.cpp 调用 g++ 工作正常并按预期运行,但用 Test2.cpp 和 Test1.cpp 调用 g++ 失败,因为 main 被定义了多次。但是,使用 -DFN_MAIN 和两个源文件调用 g++ 可以解决此问题。有什么办法可以解决这个问题吗?我认为这个问题是由于我对 C++ 预处理器的理解不够全面所致。

注意:我这样做的动机是减少我正在从事的项目的代码大小。实际项目包括独立版本的 Test1.cpp 和其他几个使用 Test1.cpp 函数的程序。

最佳答案

预处理器按顺序运行每个源文件。一个 .cpp 文件中定义的宏不会影响另一个 .cpp 文件中定义的宏。

一个选项是在 header 中定义 FN_MAIN:然后当 Test1.cpp 包含该 header 时,宏仍将被定义。但是,我认为在命令行上定义宏可能更清晰;不过,这取决于您的具体用例。

另一种选择是将 Test1.cpp main() 移动到一个单独的 .cpp 文件中,并用它构建一个单独的可执行文件。

关于c++ - 关于使用#define 有条件地排除主函数时的 C++ 预处理器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4019770/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com