C语言编译过程详解:从源代码到可执行文件的四个关键步骤
创作时间:
作者:
@小白创作中心
C语言编译过程详解:从源代码到可执行文件的四个关键步骤
引用
1
来源
1.
https://cloud.tencent.com/developer/article/2474526
C语言的编译过程涉及几个关键步骤、概念和细节,每个步骤都有助于将人类可读的源代码转换为可执行的机器码。以下是详细的解释和示例:
c 编译过程将作为输入的源代码转换为目标代码或机器代码。编译过程可分为预处理、编译、汇编和链接四个步骤。
一、什么是编译?
编译是将源代码转换为目标代码的过程。它是在编译器的帮助下完成的。编译器检查源代码是否存在语法或结构错误,如果源代码没有错误,则生成目标代码。
二、编译过程中的步骤:
- 预处理:
- 概念:预处理器 (cpp) 处理以 # 开头的指令,如 #include 、 #define 和 #ifdef 。它通过展开宏和包含头文件来准备源代码进行编译。
- 细节:将源代码转换为预处理后的中间形式。源代码是在文本编辑器中编写的代码,源代码文件的扩展名为 .c 。此源代码首先传递给预处理器,然后预处理器扩展此代码。展开代码后,扩展的代码将传递给编译器。
- 示例:
- 后缀: .i (生成的预处理后的源文件)。
- 编译:
- 概念:编译器 (gcc, clang) 将预处理后的源代码翻译成特定于目标体系结构的汇编语言。
- 细节:执行词法分析、语法分析、语义分析和优化。由预处理器扩展的代码将传递给编译器。编译器将此代码转换为汇编代码。或者我们可以说 C 编译器将预处理的代码转换为汇编代码。
- 示例:
- 后缀: .s (生成的汇编代码文件)。
- 汇编:
- 概念:汇编器 (as) 将汇编代码转换为可重定位的机器码(目标代码)。
- 细节:将汇编指令转换为机器码指令。使用汇编程序将汇编代码转换为目标代码。汇编程序生成的目标文件的名称与源文件的名称相同。在 DOS 中,目标文件的扩展名是 .obj ,在 UNIX 中,扩展名是 .o 。如果源文件的名称为 hello.c ,则目标文件的名称将为 hello.obj 。
- 示例:
- 后缀: .o (生成的目标文件)。
- 链接:
- 概念:链接器 (ld) 将多个目标文件组合在一起,并解决外部引用,生成最终的可执行代码。
- 细节:执行符号解析、为变量和函数分配最终地址,并链接必要的库文件。主要是,所有用 C 编写的程序都使用库函数。这些库函数是预先编译的,并且这些库文件的目标代码以 .lib (或 .a )扩展名存储。链接器的主要工作是将库文件的目标代码与我们程序的目标代码相结合。有时,当我们的程序引用其他文件中定义的函数时,会出现这种情况;那么linker在这方面起着非常重要的作用。它将这些文件的目标代码链接到我们的程序。因此,我们得出结论,链接器的工作是将程序的目标代码与库文件和其他文件的目标代码链接起来。链接器的输出是可执行文件。可执行文件的名称与源文件的名称相同,但仅在扩展名上有所不同。在DOS中,可执行文件的扩展名为 .exe ,而在UNIX中,可执行文件可以命名为 a.out 。例如,如果我们在程序中使用 printf() 函数,则链接器会将其关联的代码添加到输出文件中。
- 示例:
- 后缀:(可执行文件通常没有特定的后缀,常见的是没有后缀或 .out )。
三、其他概念和细节:
- 编译器优化:提升代码性能和大小。
- 目标文件:包含机器码和符号。
- 静态与动态链接:静态链接库和动态链接库的嵌入与运行时链接。
- 可执行文件格式:各种操作系统特定的格式(如 ELF、PE)。
- .hex
和
.bin
文件通常不是C语言编译过程的直接产物,而是在嵌入式系统开发中常见的文件格式,用于存储程序或数据的二进制表示。这些文件通常是在程序已经编译、链接并生成了可执行文件之后,通过特定的工具或者转换过程生成的。因此,它们不属于C语言编译过程的标准阶段,但是在嵌入式开发中是非常常见的文件格式。 - .hex 文件:通常用于存储以十六进制格式表示的固件或程序映像,适用于多种嵌入式系统和芯片编程器。
- .bin 文件:通常用于存储原始的二进制数据,可以包括程序或者数据文件,常见于嵌入式系统和低级系统编程中。
示例 1 解释:
对于给定的C程序示例:
#include <stdio.h>
#define MAX 100
int main() {
printf("Max value: %d\n", MAX);
return 0;
}
- 预处理:展开 #include <stdio.h> 并将 MAX 替换为 100 。
- 编译:将C源代码转换为汇编语言。
- 汇编:将汇编指令转换为机器码。
- 链接:将机器码与标准库函数(如 printf )结合,生成最终的可执行文件。
示例 2 解释:
#include <stdio.h>
int main()
{
printf("Hello World !");
return 0;
}
现在,我们将创建上述程序的流程图:
在上面的流程图中,执行程序需要执行以下步骤:
- 首先,将输入文件(即 hello.c )传递给预处理器,预处理器将源代码转换为扩展的源代码。扩展源代码的扩展将是 hello.i 。
- 扩展的源代码将传递给编译器,编译器将此扩展的源代码转换为汇编代码。程序集代码的扩展名为 hello.s 。
- 然后,将此汇编代码发送到汇编程序,汇编程序将程序集代码转换为目标代码。
- 创建目标代码后,链接器将创建可执行文件。然后,加载程序将加载执行的可执行文件。
理解这些步骤有助于优化代码、调试问题,并了解C编程中的平台特定细节。
热门推荐
用火星旅行解释相对论的时间
黑洞研究讲解:从基础理论到最新发现
黄玉的寓意:财富、健康与文化传承
异地婚姻登记需要什么?一文详解所需材料和办理流程
驾驶座椅如何调合适—提升驾驶舒适度与安全性
保函:担保合同中的重要一环
辛巳时是什么意思?详解庚辰日辛巳时出生命运
职业生涯助攻总数达381次,梅西是历史第一助攻专家?赛季首秀再添佳绩
行李箱什麼材質最好?纖維、PC、ABS 5大材質耐刮抗撞評比!
CPU选购终极指南:从游戏到办公,这几点让你不花冤枉钱!
铲屎官必知:猫咪尿闭的原因、症状与应对方法
猫咪闭尿怎么办?症状识别与紧急处理全攻略
合营项目管理重点任务有哪些
热力管网监测系统:提升供热效率,保障城市温暖
企业竞业限制协议的合法性与适用范围深度解析
“竞业”成“禁业”,谨防竞业限制的那些“花招”
应对白羽鸡价格暴跌 “管理战”与“信息战”成关键
五谷之首的谷子是什么?为何现在“谷子”少有人种植了?
装修新手必看:吸顶灯选购全攻略,防坑宝典
高铁管制器具的认定标准
Excel中数字自动分隔的多种方法
发现早期肺结核的主要方法是什么
法律舆论是什么?从定义到影响的全面解析
信息差:2024年报预喜潮涌,哪些行业率先复苏?
通便止泻药都有哪些?家中要备蒙脱石散吗?
止泻药有哪些常备药?怎样正确使用止泻药?
匈奴大举进犯,刘邦有韩信这等兵仙,却为何要向匈奴称臣?
喝酒“上脸”是能喝的表现?
2025公积金新政:额度翻倍+利率双降!月供省出一年工资?
法院起诉瓜子网:如何依法维权与高效诉讼策略