C++语言中多文件组合方式之经典

简介: C++语言中多文件组合方式之经典

1、解决问题:C++多个文件如何进行组合编译

以前大家经常操作,基本上所有的代码都是写到一个源文件中,例如:

//main.cpp
#include <iostream>
using namespace std;
class Student{
public:
    char *name;
    int age;
    float score;
    void say(){
        cout<<name<<"的年龄是"<<age<<",成绩是"<<score<<endl;
    }
};
int main(){
    Student *pStu = new Student;
    pStu -> name = "小明";
    pStu -> age = 15;
    pStu -> score = 92.5f;
    pStu -> say();
    delete pStu;  //删除对象
    return 0;
}

最常见的就是,将所有的代码都位于main.cpp文件中。对于工程量小的代码来说,无可厚非,但是随着代码量的膨胀到几千行甚至上万行后,就应该考虑将代码,分散到多个文件中。注意:这里所谓的分散,并不是胡乱的划分。为了方便后期的维护,分散代码应该遵循一个基本的原则:实现相同功能的代码应存储在一个文件中。


      事实上,一个完整的C++项目常常是由多个代码文件组成的,根据后缀名的不同,大致可以将它们分为如下两类:


       第一个:h 文件:又称“头文件”,用于存放常量、函数的声明部分、类的声明部分;


       第二个:cpp 文件:又称“源文件”,用于存放变量、函数的定义部分,类的实现部分。


注意:实际上,.cpp 文件和 .h 文件都是源文件,除了后缀不一样便于区分和管理外,其他的几乎相同,在 .cpp 中编写的代码同样也可以写在 .h 中。之所以将 .cpp 文件和 .h 文件在项目中承担的角色进行区别,不是 C++ 语法的规定,而是约定成俗的规范,读者遵守即可。


        最重要的是,虽然类内部的成员函数可以在声明的同时进行定义(自动内敛函数),但原则上不推荐这样使用。也就是说,即便定义成员函数的代码很少,其定义也应该放在适当的.cpp文件中。


         另外对于一些系统提供的库,第三库以及版权和保密性的考虑,大多数已经编译好的二进制文件,其中可能仅包含.h文件,而没有.cpp文件。


        按照上面的例子进行分类:

//student.h
class Student {
public:
    const char *name;
    int age;
    float score;
    void say();
};
//student.cpp
#include <iostream>   //std::cout、std::endl
#include "student.h"  //Student
void Student::say() {
    std::cout << name << "的年龄是" << age << ",成绩是" << score << std::endl;
}
//main.cpp
#include "student.h"  //Student
int main() {
    Student *pStu = new Student;
    pStu->name = "小明";
    pStu->age = 15;
    pStu->score = 92.5f;
    pStu->say();
    delete pStu;  //删除对象
    return 0;
}

正常情况下,项目的基本情况  

项目─┐├ student.h

     ├ student.cpp

     └ main.cpp

执行结果为:


小明的年龄是15,成绩是92.5


如上所示,在对之前的程序进行合理地划分时,需要额外将 "student.h" 分别引入到 student.cpp 文件和 main.cpp 文件中,理由很简单,因为这 2 个文件中需要使用 student.h 文件声明的 Student 类,就如同我们在使用 cin 和 cout 时需要提前引入 <iostream> 头文件一样。


注意,引入编译器自带的头文件(包括标准头文件)用尖括号,例如 <iostream>;引入自定义的头文件用 "" 双引号,例如 "student.h"。


可以看到,之前的一段程序被划分到了 3 个文件中,其中:

  • student.h 头文件负责存储 Student 类的声明部分;
  • student.cpp 文件负责存储 Student 类中成员函数的定义部分;
  • main.cpp 文件负责存储主程序(main() 函数)。

经过上面这样划分,当后期想查看 Student 类有哪些成员时,就可以直接打开 student.h 文件,想查看某个成员函数的具体实现时,可以打开 student.cpp 文件。


除此之外,当一个项目中的文件过多时,还可以将它们分散存储到不同的文件夹下。例如:


项目─┐

     ├─ include ┐

     │           ├ student.h

     │           └ ...

     ├─ source ┐

      ...        ├ student.cpp

                 ├ main.cpp

                 └ ...


总结:将所有的头文件存储在 include 文件夹下,将所有的 .cpp 文件存储在 source 文件夹下。总之项目越大,多文件编程的优势越明显。


目录
相关文章
|
8月前
|
存储 C++
C++语言中指针变量int和取值操作ptr详细说明。
总结起来,在 C++ 中正确理解和运用 int 类型地址及其相关取值、设定等操纵至关重要且基础性强:定义 int 类型 pointer 需加星号;初始化 pointer 需配合 & 取址;读写 pointer 执向之处需配合 * 解引用操纵进行。
659 12
|
9月前
|
C++ Windows
.NET Framework安装不成功,下载`NET Framework 3.5`文件,Microsoft Visual C++
.NET Framework常见问题及解决方案汇总,涵盖缺失组件、安装失败、错误代码等,提供多种修复方法,包括全能王DLL修复工具、微软官方运行库及命令行安装等,适用于Windows系统,解决应用程序无法运行问题。
1291 3
|
存储 算法 安全
企业员工数据泄露防范策略:基于 C++ 语言的布隆过滤器算法剖析[如何防止员工泄密]
企业运营过程中,防范员工泄密是信息安全领域的核心议题。员工泄密可能致使企业核心数据、商业机密等关键资产的流失,进而给企业造成严重损失。为应对这一挑战,借助恰当的数据结构与算法成为强化信息防护的有效路径。本文专注于 C++ 语言中的布隆过滤器算法,深入探究其在防范员工泄密场景中的应用。
267 8
|
存储 负载均衡 算法
基于 C++ 语言的迪杰斯特拉算法在局域网计算机管理中的应用剖析
在局域网计算机管理中,迪杰斯特拉算法用于优化网络路径、分配资源和定位故障节点,确保高效稳定的网络环境。该算法通过计算最短路径,提升数据传输速率与稳定性,实现负载均衡并快速排除故障。C++代码示例展示了其在网络模拟中的应用,为企业信息化建设提供有力支持。
353 15
|
存储 算法 安全
基于哈希表的文件共享平台 C++ 算法实现与分析
在数字化时代,文件共享平台不可或缺。本文探讨哈希表在文件共享中的应用,包括原理、优势及C++实现。哈希表通过键值对快速访问文件元数据(如文件名、大小、位置等),查找时间复杂度为O(1),显著提升查找速度和用户体验。代码示例展示了文件上传和搜索功能,实际应用中需解决哈希冲突、动态扩容和线程安全等问题,以优化性能。
|
算法 C++
2022年第十三届蓝桥杯大赛C/C++语言B组省赛题解
2022年第十三届蓝桥杯大赛C/C++语言B组省赛题解
442 5
|
存储 编译器 C语言
深入计算机语言之C++:类与对象(上)
深入计算机语言之C++:类与对象(上)
207 0
|
存储 分布式计算 编译器
深入计算机语言之C++:C到C++的过度-2
深入计算机语言之C++:C到C++的过度-2
150 0
|
编译器 Linux C语言
深入计算机语言之C++:C到C++的过度-1
深入计算机语言之C++:C到C++的过度-1
209 0
|
Linux C++
Linux c/c++文件虚拟内存映射
这篇文章介绍了在Linux环境下,如何使用虚拟内存映射技术来提高文件读写的速度,并通过C/C++代码示例展示了文件映射的整个流程。
503 0