将c语言源代码编译成可执行程序的过程包括以下几个步骤,每一步都对源代码进行了不同的处理:
-
预处理(.c文件 -> .i文件)
目的:将头文件和宏进行替换,取消注释。文件从
code.c变为code.i。
现在我使用指令对
.c文件进行预处理,让我们来看一下预处理后的代码:gcc -E code.c -o code.i
可以看到头文件确实被库
中的代码替换了;而其他代码保持不变。
注意:替换后的代码仍然是C语言代码,只是变得更加简洁(没有注释)。
-
编译(.i文件 -> .s文件)
目的:将C语言代码处理为汇编代码。
这次我们直接使用预处理过的文件进行下一步的汇编:
gcc -S code.i -o code.s

我们发现这次处理后的代码已经变成我们看不懂的了,这就是已经从C代码转换为了汇编代码。
-
汇编(.s文件 -> .o文件)
目的:进一步处理汇编代码,形成机器可识别的代码(可重定向目标文件)。
这次我们使用上一次的
code.s文件继续编译,会报错;所以我们这次使用code.c来进行处理:gcc -c code.c -o code.o

这次的代码和上次的有变化,但还是看不懂。我们记住是从汇编代码处理为了机器可识别的代码,变成了可重定向目标文件。
-
链接(.o文件 -> exe文件)
目的:产生可执行文件。
这次使用
.o文件链接为exe文件:gcc code.o -o code

E、S、c选项先有语言还是先有编译器?答案是先有语言,但并不是先有当前编译器的语言。在最早的时期,人们都是使用二进制语言来编写程序的;然而,为了更加方便地编写代码,人们使用二进制编写了汇编代码,因此汇编语言产生了。然后,人们又使用汇编代码开发出了汇编代码编译器,这个过程就叫做语言自举。
动态连接和静态连接库的位置,我们平时使用的头文件都是声明,实现都在库文件中,库一般都在
/usr/include目录下。
连接方式分为动态链接和静态连接。
查看文件使用的哪种库?

根据红色的部分判断是什么库?
云服务器默认没有安装C/C++静态标准库,我们可以使用
yum按照下面的指令安装:sudo yum install libstdc++-static
Makefile自动构建工具
青鸟内测(手机app封装、托管系统)下载注意:请在linux环境下测试或生产使用 青鸟内测是一个移动应用分发系统,支持安卓苹果应用上传与下载,并且还能快捷封装网址为应用。应用内测分发:一键上传APP应用包,自动生成下载链接和二维码,方便用户内测下载。应用封装:一键即可生成app,无需写代码,可视化编辑、 直接拖拽组件制作页面的高效平台。工具箱:安卓证书生成、提取UDID、Plist文件在线制作、IOS封装、APP图标在线制作APP分发:
我们可以把
Makefile理解为指令的集合;Makefile文件里有我们写好的很多指令,然后我们对Makefile进行操作就可以更加便捷地调用其内部的指令。举个例子,比如有一份
proc.c的C语言文件,在使用的过程中需要多次对文件编译,通常情况下每次编译都要使用gcc proc.c -o proc生成可执行文件proc;这样操作是很麻烦的。Makefile工具可以很好地解决这种频繁调用编译的问题。Makefile的使用:
第一行:
proc是生成的文件,proc.c是依赖文件;冒号代表的是依赖关系。第二行需要空一个Tab键的长度(不能使用空格),然后输入要执行的命令。
我们直接使用指令
make就可以调用gcc proc.c -o proc指令了,这样使用起来是不是会很方便?那是不是也可以这样方便地清理文件呢?
答案是可以的:

不同的是删除代码不需要依赖任何文件,所以没有依赖文件。我们需要使用
make clean来调用清除可执行程序的指令。为什么
gcc proc.c -o proc直接使用make就可以呢?这是因为代码的执行顺序是从上到下的,
make默认调用第一个依赖关系命令,这里实际上make的完整指令应该是make proc。目标的调用顺序
现在来写一下C语言编译的完整过程:

程序执行的顺序是从上往下执行的,当执行
gcc proc.o -o proc时,这时候还没有proc.o文件,所以就会先把这一行的指令放入堆栈中,依次类推,直到最后gcc -E proc.c -o proc.i产生了proc.i文件,紧接着指令依次出栈;最后执行完毕。.PHONY伪目标
在没有使用
.PHONY的情况下,proc.c文件在最新版本时,只能make一次。这样做的目的是提高效率。
在此编译会给出“
procis up to date”,proc可执行程序是最新的,不需要再次编译。如何查看文件是否是最新的?

stat文件名:查看文件的最近一次的更改时间相关的信息。正常情况下,proc.c文件的时间应该是在proc之前的,因为先有proc.c再有proc;这是我刚才更新了一下proc.c文件,这时候proc.c比proc还要新,所以这个时候是可以重新编译的。使用伪目标忽略时间:

如果我们对
make proc设置伪目标,那样就可以无限次地编译了。
总结









