为什么c++有头文件和。cpp文件?


当前回答

这是预处理器声明接口的方式。将接口(方法声明)放到头文件中,实现放到cpp中。使用您的库的应用程序只需要知道接口,它们可以通过#include访问该接口。

其他回答

通常情况下,您希望有一个接口的定义,而不必交付整个代码。例如,如果您有一个共享库,您将附带一个头文件,该文件定义了共享库中使用的所有函数和符号。如果没有头文件,则需要发布源代码。

在一个项目中,头文件至少有两个用途:

清晰性,即通过保持接口与实现分离,更容易阅读代码 编译时间。通过尽可能只使用接口,而不是完整的实现,可以减少编译时间,因为编译器可以简单地对接口进行引用,而不必解析实际代码(理想情况下,只需要一次完成)。

主要原因是将接口从实现中分离出来。头文件声明了一个类(或任何正在实现的类)将做什么,而cpp文件定义了它将“如何”执行这些功能。

这减少了依赖关系,因此使用头文件的代码不一定需要知道实现的所有细节,也不需要知道为此所需的任何其他类/头文件。这将减少编译时间,以及当实现中的某些内容发生更改时所需的重新编译量。

它并不完美,您通常会求助于诸如Pimpl Idiom之类的技术来正确地分离接口和实现,但这是一个良好的开端。

因为c++从C继承了它们。

回应MadKeithV的回答,

这减少了依赖关系,因此使用标头的代码不会 必然需要知道实现的所有细节和任何 其他类/头只需要这样做。这将减少 编译次数,以及需要的重新编译量 实现中的某些内容发生了变化。

另一个原因是头文件为每个类提供了唯一的id。

如果我们有

class A {..};
class B : public A {...};

class C {
    include A.cpp;
    include B.cpp;
    .....
};

我们会有错误,当我们试图构建项目时,因为A是B的一部分,有了头文件,我们就可以避免这种头痛……

因为在c++中,最终的可执行代码不携带任何符号信息,它或多或少是纯机器代码。

因此,您需要一种方法来描述一段代码的接口,这种方法与代码本身是分开的。该描述在头文件中。