为什么全局变量由另一个源文件中的类初始化
Why do global variable get initialized by class in another source file?
例如,我有两个源,每个源中都有一个类和一个静态函数。类、函数和全局变量的名称相同:(我添加的功能只是为了比较。)
//A.cpp
#include <stdio.h>
static bool FooFunc() { printf("Hello from function in A!n"); return true; }
class FooClass
{
public:
FooClass() { printf("Hello from class in A!nn"); }
};
static bool fooFunc = FooFunc();
static FooClass fooClass;
和
//B.cpp
#include <stdio.h>
static bool FooFunc() { printf("Hello from function in B!n"); return true; }
class FooClass
{
public:
FooClass() { printf("Hello from class in B!nn"); }
};
static bool fooFunc = FooFunc();
static FooClass fooClass;
结果:
Hello from function in A!
Hello from class in A!
Hello from function in B!
Hello from class in A!
"B.cpp"中的类是否以某种方式被忽略?若是这样,编译器不应该给我一些错误或警告吗?我试过"g++"answers"clang"编译器,行为相同。
在c++中,source
文件被称为翻译单元(在预处理器之后)。在编译每个单元之后,object
文件(.o)然后通过链接器链接在一起。现在,每个类在链接时都有一个唯一的标识符(因此它可以与其他翻译单元放在一起,以解析变量等)。源文件具有相同的类名,从而违反了一个定义规则。所以,你有两个选择。第一个是重命名两个类中的一个,第二个是将它们放在namespace
下。希望我能帮上忙。
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 在C和C++中初始化结构中的数组
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- C++ 编译时检查微控制器引脚是否已从其他源文件初始化
- 为什么全局变量由另一个源文件中的类初始化