makefile文件

      make是一个命令,makefile是一个文件。make命令执行时,需要一个 Makefile 文件,以告诉make命令需要怎么样的去编译和链接程序。一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。makefile 带来的好处就是------“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率

下面进行具体说明。

1、建立test.h、test.c和main.c文件

【Linux】make的工作原理和makefile文件_第1张图片

2、如果不建立makefile文件,我们就需要依次进行编译链接

【Linux】make的工作原理和makefile文件_第2张图片

3、编写makefile文件

一旦改变了某一文件的程序,就需要重新进行上述操作,太过繁琐,于是我们建立makefile文件进行自动化编译,包括自动清除所有编译结果。

【Linux】make的工作原理和makefile文件_第3张图片

注:在依赖方法那行,一定要以Tab键开头。“.PHONY”表示,clear是个伪目标文件。

● make的工作原理

      在默认的方式下,也就是我们只输入make命令,那么make会进行以下步骤。

1、make会在当前目录下找名字叫“Makefile”或“makefile”的文件。
2、如果找到,它会找文件中的第一个目标文件(target),在上面的例子中,他会找到“edit”这个文件,并把这个文件作为最终的目标文件。
3、如果edit文件不存在,或是edit所依赖的后面的 .o 文件的文件修改时间要比edit这个文件新,那么,他就会执行后面所定义的命令来生成edit这个文件。
4、如果edit所依赖的.o文件也不存在,那么make会在当前文件中找目标为.o文件的依赖性,如果找到则再根据那一个规则生成.o文件。(这有点像一个堆栈的过程)
5、当然,你的C文件和H文件是存在的啦,于是make会生成 .o 文件,然后再用 .o 文件生命make的终极任务,也就是执行文件edit了。
这就是整个make的依赖性,make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。

》》》输入make命令

【Linux】make的工作原理和makefile文件_第4张图片

输入make命令后自动生成了-i,-s,-o和main文件。

【Linux】make的工作原理和makefile文件_第5张图片

》》》输入make clear命令

wKioL1dOVO7gDk_YAAAdAgRT-0E438.png-wh_50

在依赖关系前加@,可屏蔽细节

【Linux】make的工作原理和makefile文件_第6张图片

》》》ctags:linux代码查看

       ctags是vim下方便代码阅读的工具。尽管ctags也可以支持其它编辑器,但是它正式支持的只有VIM。并且VIM中已经默认安装了Ctags,它可以帮助程序员很容易地浏览源代码。

       如果没有安装ctags,先进行ctags的安装,安转后在指定的源码位置生成tags文件,例如ctags test.c再ls会存在tags文件,该文件存放了test.c的源代码。

【Linux】make的工作原理和makefile文件_第7张图片

【Linux】make的工作原理和makefile文件_第8张图片

      我们查看tags内容就可以发现,原来tags就是linux内核代码中各个元素的索引,这也就是ctags结合vim可以快速进行定位的原因了(查询就是通过这个文件内容来定位的)。

》》》cat 文件名

cat主要有三大功能:
1.一次显示整个文件。$ cat filename
2.从键盘创建一个文件。$ cat > filename  
   只能创建新文件,不能编辑已有文件.
3.将几个文件合并为一个文件: $cat file1 file2 > file

例如:cat test.c 显示test.c代码

【Linux】make的工作原理和makefile文件_第9张图片