C++ 编译体系入门指北

前言

之从入坑C++之后,项目中的编译构建就经常跟CMake打交道,但对它缺乏系统的了解,遇到问题又陷入盲人摸象。对C++的编译体系是如何发展的,为什么要用CMake,它的运作原理是如何的比较感兴趣,所以就想系统学习一下,特此整理本篇文章作为入门指引。

GCC 编译流程

GCC,全称GNU Compiler Collection(GNU编译器套件),是由GNU项目开发的一款编译器软件,可以编译多种编程语言,包括C、C++、Objective-C、Fortran、Ada等。

image.png

图引自:https://www3.ntu.edu.sg/home/ehchua/programming/cpp/gcc_make.html

C/C++从代码到最终可执行程序的过程大致分为以下几个阶段:

  1. 预处理(Preprocessing):预处理器处理源代码中的预处理指令,如#define、#include等。预处理器会将#include指令包含的文件内容插入到该指令的位置,处理#define定义的宏等。预处理后的文件通常以.i为后缀。
  2. 编译(Compilation):编译器将预处理后的文件(.i文件)翻译成汇编语言。编译器会检查代码的语法,进行优化,然后生成汇编代码。生成的汇编代码文件通常以.s为后缀。
  3. 汇编(Assemble):汇编器将汇编代码转换为机器代码,生成目标文件。目标文件包含了程序的机器代码,但是这些代码可能还不能直接执行,因为它们可能还依赖于其他的目标文件或库。生成的目标文件通常以.o(在Unix-like系统中)或.obj(在Windows系统中)为后缀。
  4. 链接(Linking):链接器将一个或多个目标文件以及需要的库链接成一个可执行文件或库。链接器会解析目标文件之间的依赖关系,将依赖的目标文件或库链接在一起。如果目标文件之间存在未解决的依赖关系,链接器会报错。

最简单的例子:

//main.c
#include <stdio.h>int main() 
{printf("Hello World!\n");return 0;
}
  • 预处理:通过gcc -E main.c命令可以看到预处理结果
  • 编译:通过gcc -S mian.c命令可以生成汇编文件main.s
  • 汇编:通过gcc -c main.c 命令可以生成文件main.o
  • 链接:通过gcc main.o可以生成a.out 可执行文件

编译工具链


编译工具链(Toolchain)是指一组用于将源代码转换为可执行文件或库的工具和程序。一个典型的编译工具链包括编译器、汇编器、链接器、库和调试器等组件。

  • Windows 平台主要使用微软提供的工具链——MSVC。
  • Linux 平台主要是GCC。
  • MacOS 平台主要使用Clang 和 LLVM。

构建系统

随着项目工程越来越复杂,源代码文件越来越多,编译配置项根据场景的不同越来越复杂(例如,Debug模式和Release模式下编译参数不一样)的时候,依然通过直接调用这些命令的时候就会很复杂,我们需要编写大量复杂的命令行才能完成一个复杂项目的编译工作。基于这样的背景,我们诞生了构建系统(Build System)。

在Linux/Unix上的构建系统历史最悠久的就是make工具,而与之配合的就是Makefile配置文件。
Make是命令行工具,Makefiles 配置文件指明了项目中具有哪些源代码、编译的规则逻辑等信息。
当make执行的时候,读取Makefile配置文件,生成GCC相关的调用命令行,再调用GCC的相关命令行工具进行编译构建。
image.png

图片引自:https://www.cnblogs.com/w4ngzhen/p/17695080.html

构建系统在底层依赖使用的是编译工具链,只是进行了一定的用户友好的抽象,并降低了项目编译的复杂度。

跨平台构建系统工具

图参考:https://www.cnblogs.com/w4ngzhen/p/17695080.html

CMake 是C++ 中被广泛使用的开源构建系统工具,支持多种编译器和平台。它通过生成本地构建系统(如Makefiles、Visual Studio 项目文件等)来实现跨平台构建。

包管理器

早期阶段

在C++ 早期阶段,开发者主要依赖于手动管理库和依赖项。这通常包括下载源代码或预编译的二进制文件,然后将其集成到项目中。这种方式虽然灵活,但容易出错且难以维护。

Autotools 和 CMake

随着项目规模的扩大和复杂性的增加,构建系统如 Autotools 和 CMake 开始流行。这些工具帮助开发者自动化构建过程,但它们并不是包管理器。它们主要解决的是构建和配置问题,而不是依赖管理。

pkg-config

pkg-config 是一个用于管理编译和链接参数的工具,广泛用于 Unix 系统。虽然它简化了库的使用,但仍然需要手动安装和管理库。

Conan

Conan 是一个现代的、跨平台的 C++ 包管理器,旨在解决依赖管理问题。它支持多种构建系统(如 CMake、Autotools、MSBuild 等),并且可以与 CI/CD 管道集成。Conan 提供了一个中央仓库(Conan Center),开发者可以在其中发布和查找包。

vcpkg

vcpkg 是由微软开发的 C++ 包管理器,专注于简化库的获取和集成。它特别适合 Windows 平台,但也支持 Linux 和 macOS。vcpkg 提供了一个中央仓库,用户可以轻松地安装和管理库

Hunter

Hunter 是另一个 C++ 包管理器,基于 CMake。它通过 CMake 的外部项目功能来管理依赖项,适合那些已经使用 CMake 作为构建系统的项目。

Buckaroo

Buckaroo 是一个基于 Buck 构建系统的 C++ 包管理器。它旨在提供快速、可重复的构建,并支持跨平台开发

CPM

CPM 是一个基于 CMake 的轻量级包管理器,使用 CMake 的 FetchContent 模块来下载和管理依赖项。它适合那些希望最小化外部依赖的项目。

C++ 编译体系演进

总结

本文介绍了 C++ 编译体系从最早期的手工管理依赖,随着项目的复杂性增加演进成不同平台的本地构建系统,随着面对一致性与可维护性的问题发展出跨平台构建系统的工具,后面针对代码仓库的依赖管理的诉求又发展出包管理器。罗马并非一天建成,C++ 编译体系也随着软件工程的发展也逐步演进当中,我们可以针对不同业务诉求来选择相应的工具。通过了解编译体系的发展脉络,能对自己项目的编译构建问题有更深刻的理解,进而提升项目工程化组织能力,提升效能。

附录

  • https://cmake.org/
  • https://zh.wikipedia.org/zh-cn/CMake
  • https://gavinliu6.github.io/CMake-Practice-zh-CN/#/foreword
  • https://zhuanlan.zhihu.com/p/62083969
  • https://www.cnblogs.com/w4ngzhen/p/17695080.html
  • 程序员需要知道的C/C++编译知识
  • modern c++ 的 编译工具链、包管理和坑 - mian的技术分享

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/373642.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CentOS7 安装 git 命令

通过yum源install下载的git版本比较低&#xff0c;不推荐此方式安装。 官网下载最新版git源码&#xff1a;Git 1. 解压安装包 tar -xzvf git-2.45.2.tar.gz 2. 安装相关依赖 yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc perl-ExtUtils…

第三方商城对接重构(HF202407)

文章目录 项目背景一、模块范围二、问题方案1. 商品模块2. 订单模块3. 售后4. 发票5. 结算单 经验总结 项目背景 作为供应商入围第三方商城成功&#xff0c;然后运营了一段时间&#xff0c;第三方通知要重构&#xff0c; 需要重新对接打通接口完成系统对接&#xff0c;能贯穿整…

【QT中实现摄像头播放、以及视频录制】

学习分享 1、效果图2、camerathread.h3、camerathread.cpp4、mainwindow.h5、mainwindow.cpp6、main.cpp 1、效果图 2、camerathread.h #ifndef CAMERATHREAD_H #define CAMERATHREAD_H#include <QObject> #include <QThread> #include <QDebug> #include &…

Mybatis的优缺点及适用场景?

目录 一、什么是Mybatis&#xff1f; 二、Mybatis框架的特点 三、Mybatis框架的优点&#xff1f; 四、MyBatis 框架的缺点&#xff1f; 五、MyBatis 框架适用场合&#xff1f; 六、代码示例 1. 配置文件 mybatis-config.xml 2. 映射文件 UserMapper.xml 3. Java 代码…

coco_eval 使用

参考 coco eval 解析 COCO目标检测比赛中的模型评价指标介绍&#xff01; coco 的评估函数对应的是 pycocotools 中的 cocoeval.py 文件。 从整体上来看&#xff0c;整个 COCOeval 类的框架如图&#xff1a; 基础的用法为 # The usage for CocoEval is as follows: cocoGt…

深入解析视频美颜SDK:开发直播平台主播专用的美颜工具教学

本篇文章&#xff0c;笔者将深入解析视频美颜SDK的原理与应用&#xff0c;帮助开发者打造适用于直播平台的专业美颜工具。 一、视频美颜SDK的基础原理 视频美颜SDK其核心技术包括人脸检测、面部特征点识别、图像增强和特效应用等。 二、视频美颜SDK的开发流程 环境搭建 首先…

Redis+Caffeine 实现两级缓存

RedisCaffeine 实现两级缓存 背景 ​ 事情的开始是这样的&#xff0c;前段时间接了个需求&#xff0c;给公司的商城官网提供一个查询预计送达时间的接口。接口很简单&#xff0c;根据请求传的城市仓库发货时间查询快递的预计送达时间。因为商城下单就会调用这个接口&#xff…

人工智能建立在对象存储上的真正原因

tl;dr: 在这篇文章中&#xff0c;我们将探讨 AI 工作负载依赖高性能对象存储的四个技术原因。 1. 对非结构化数据没有限制 在当前的机器学习范式中&#xff0c;性能和能力与计算成比例&#xff0c;计算实际上是数据集大小和模型大小的代理&#xff08;神经语言模型的缩放定律&a…

74HC165芯片验证

目录 0x01 74HC165芯片介绍0x02 编程实现 0x01 74HC165芯片介绍 74HC165的引脚定义如下&#xff0c;长这个样子 ABCDEFGH是它的八个输入引脚&#xff0c;例如你可以将它连接按键&#xff0c;让它来读取8个按键值。也可以将他级联其它的74165&#xff0c;无需增加单片机GPIO引…

Msfvenom制作自己的专属Shell

Msfvenom制作自己的专属Shell 如何通过Msfvenom来生成用户自己的专属Shell?有时候我们上传Shell到目标主机后&#xff0c;不仅我们自己可以连接&#xff0c;其他用户也可以连接&#xff0c;有时候会导致我们丢失该Shell&#xff0c;甚至该shell被用户发现并查杀。 实验环境 …

HTTP 概况

Web的应用层协议是超文本传输协议(HyperTextTransferProtocol&#xff0c;HTTP)&#xff0c;它是 Web的核心。HTTP由两个程序实现:一个客户程序和一个服务器程序。客户程序和服务器程序运行在不同的端系统中&#xff0c;通过交换HTTP报文进行会话。HTTP定义了这些报文的结构以及…

【SVN-CornerStone客户端使用SVN-多人开发-解决冲突 Objective-C语言】

一、接下来,我们来说第三方的图形化界面啊, 1.Corner Stone:图形化界面,使用SVN, Corner Stone的界面,大概就是这样的, 1)左下角:是我们远程的一个仓库, 2)右上角:是我们本地的一些东西, 首先,在我的服务器上,再开一个仓库,叫做wechat, 我在这个里边,新建…

游戏AI的创造思路-技术基础-情感计算(2)

上一篇我们介绍了情感计算的基本支持&#xff0c;本篇将呈现情感计算在游戏AI中的使用实例~~~ 目录 7. 情感计算在游戏AI中的运用实例 7.1. RPG游戏中的运用实例 7.1.1. 实例背景 7.1.2. AI情感计算系统 7.1.3. 引导用户执行任务 7.1.4. 推动游戏剧情发展 7.1.5. 实例效…

如何才能半个月学习完自动化测试,成功跳槽涨薪?

一直想写类似的文章&#xff0c;但是一直没有时间&#xff0c;正好乘此周末&#xff0c;终于可以写写我的见解了<关于如何学习自动化测试>&#xff0c;其实自动化测试的知识很宽泛&#xff0c;具体细分又可以分为&#xff1a;Web自动化测试&#xff08;PythonSelenium&am…

红日靶场----(三)漏洞利用

上期已经信息收集阶段已经完成&#xff0c;接下来是漏洞利用。 靶场思路 通过信息收集得到两个吧靶场的思路 1、http://192.168.195.33/phpmyadmin/&#xff08;数据库的管理界面&#xff09; root/root 2、http://192.168.195.33/yxcms/index.php?radmin/index/login&am…

tensorflow之欠拟合与过拟合,正则化缓解

过拟合泛化性弱 欠拟合解决方法&#xff1a; 增加输入特征项 增加网络参数 减少正则化参数 过拟合的解决方法&#xff1a; 数据清洗 增大训练集 采用正则化 增大正则化参数 正则化缓解过拟合 正则化在损失函数中引入模型复杂度指标&#xff0c;利用给w增加权重&#xff0c;…

插入排序算法(C语言版)

直接插入排序 插入排序&#xff08;insert sort&#xff09;是一种简单的排序算法&#xff0c;它的工作原理与手动整理一副牌的过程非常相似。 具体来说&#xff0c;我们在未排序区间选择一个基准元素&#xff0c;将该元素与其左侧已排序区间的元素逐一比较大小&#xff0c;并…

【限时删!绝命Coding助力秋招】Python实现Boss海投脚本

hello hello~ &#xff0c;这里是绝命Coding——老白~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#xff1a;绝命Coding-CSDN博客 &a…

GenAI 技术堆栈架构师指南 - 十种工具

这篇文章于 2024 年 6 月 3 日首次出现在 The New Stack 上。 我之前写过关于现代数据湖参考架构的文章&#xff0c;解决了每个企业面临的挑战——更多的数据、老化的Hadoop工具&#xff08;特别是HDFS&#xff09;以及对RESTful API&#xff08;S3&#xff09;和性能的更大需求…

YOLOv8改进 | 注意力机制 | 增强模型在图像分类和目标检测BAM注意力【小白必备 + 附完整代码】

秋招面试专栏推荐 &#xff1a;深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 &#x1f4a1;&#x1f4a1;&#x1f4a1;本专栏所有程序均经过测试&#xff0c;可成功执行&#x1f4a1;&#x1f4a1;&#x1f4a1; 专栏目录 &#xff1a;《YOLOv8改进有效…