Makefile的使用
我们把整个工程应该如何编译链接,最终生成谁,写在Makefile文件中,然后我们通过make整个命令,make就会去读取这个Makefile文件的内容,然后根据Makefile的内容帮我们把整个工程编译链接生成最终的可执行程序。
makefile 和 make
管理工程 实现自动化编译 (和 vs 比较)示例:
vi makefile
我们只能写成Makefile或者makefile
我们用all指定最终生成的目标文件:可执行程序main程序
然后下面这一行是依赖关系:main程序要生成,依赖于3个.o文件
然后是下面一行是规则命令:如何生成可执行程序呢?
因为main.o,add.o是原本就有的,所以我们接下来要给出main.o的依赖文件
然后是规则命令
然后给出add.o的依赖文件和规则命令
然后给出max.o的依赖文件和规则命令
最后给出清理:clean,把中间的不必要的文件清理掉(把.o文件清理掉)。
我们来理解一下这个文件:
它首先要生成main,所以它首先去找main的依赖文件,找到全部的依赖文件后,通过下面的这行规则命令生成可执行程序main。
但是,通常情况下,这个依赖文件可能不具备,如果没有找到这个add.o,就跑到下面去看这个add.o有没有依赖于其他文件,这时候我们发现它依赖于add.c,然后通过下面的规则 gcc -c add.c生成add.o,有了add.o然后去找max.o,如果没有找到max.o,就去找他的依赖文件:max.c,然后按照规则命令生成max.o,以此类推。等待这3个.o文件都具备了,就利用gcc -o main main.o add.o max.o生成可执行程序main
中间可能会生成.o文件,如果我们不需要这些文件呈现给客户,我们就执行clean的命令进行清理。
注意编写红色代码部分时 先回到首部,然后按tab键,再书写代码
make
根据 makefile 文件的规则生成可执行程序
如果我们此时修改一下add.c的文件,其他文件不动。
只对刚才修改过的文件进行编译
如果我们再执行make的话
它会提醒我们没什么事情去做
我们可以清理掉整个工程,所以中间生成的文件就都没有了
重新生成:
它是怎么清除的?我们刚才改了哪个文件,怎么知道编译的时候只编译它呢?
它是根据最后修改的时间进行判断,比如说,我们在1点的时候写好所有.c文件,在2点的时候开始进行编译,那么所有.o文件就是在2点生成的,我们在3点的时候进行链接,生成可执行程序,然后在4点时我去改了add.c文件,这时候时间就不对了,本来所有的.c文件都是在1点,.o是在2点,main程序在3点,这个时间关系必须是顺序的,如果后来把add.c文件改了,时间就反过来了,add.c的最后修改的时间变成比main程序还晚,main程序是依赖add.o的,add.o是依赖add.c的,add.o文件是2点,而add.c现在是4点,说明时间是改了,触发了add.c重新生成add.o,add.o进行链接生成可执行程序main
./main 即可运行
还可以Makefile文件进行安装,在文件的末尾给个install,把可执行程序拷贝到存放命令的目录底下,就可以执行了