包含多个源文件中包含的"const"的头文件

Header file containing 'const' included in multiple source files

本文关键字:const 文件 包含 源文件 包含多      更新时间:2023-10-16

为什么包含const定义并由多个源文件包含的头文件不会给出multiple definition的编译错误?

const_in_header_file.h

const int num = 5;
//int x; //Error. Multiple defintion if included from multiple source files.

const_in_header_file_func.cpp

#include <iostream>
#include "const_in_header_file.h"
using namespace std;
void func(void)
{
   cout << "num in func() = " << num << endl;
}

const_in_header_file_main.cpp

#include <iostream>
#include "const_in_header_file.h"
using namespace std;
extern void func(void);
int main()
{
   cout << "num in main() = " << num << endl;
   func();
}

在C++全局常量是内部链接。将头文件与 cpp 文件组合后(头文件将被"插入"到 #include 所在的 cpp 文件中),每个编译单元将被编译为目标文件,然后链接在一起。这些函数和变量是内部链接,链接器将看不到,这意味着在此阶段看不到您的 const 全局。即使您在不同的对象文件中有两个或更多 const,它们也只是隐藏的。仅对于那些具有外部链接函数和变量的用户,链接器将尝试将声明与定义"组装"。例如:如果你有 extern int a;在一个编译单元中(插入 .h 的 CPP);链接器将搜索它的定义: int a;(不带外部关键字)。如果找到两个,则出现重定义错误。

对于常量,它们只是隐藏到链接器中。

因为如果它真的是一个定义而不是一个声明,那么编译器将在一次又一次地遇到定义时创建一个具有相同名称的(全局)变量 - 然后链接器不知道如何处理结果对象代码文件中具有相同名称的多个符号。

可能是因为你写了头文件...但未能包括"标题护卫"。

缺少"标头保护"会导致编译错误。另一种可能性是你没有使用"extern"。 这将导致链接错误。

例如:

#ifndef MY_HEADER_H
#define MY_HEADER_H
extern int myglobal;
#endif

请看以上两个链接。 如果添加防护和/或使用"extern"不能解决问题,请发布失败的代码片段。