详解linux下make命令的使用方法
本文我们将用一些实例来讨论make命令背后的工作机制。
Make如何工作的
对于不知道背后机理的人来说,make命令像命令行参数一样接收目标。这些目标通常存放在以“Makefile”来命名的特殊文件中,同时文件也包含与目标相对应的操作。更多信息,阅读关于Makefiles如何工作的系列文章。
当make命令第一次执行时,它扫描Makefile找到目标以及其依赖。如果这些依赖自身也是目标,继续为这些依赖扫描Makefile建立其依赖关系,然后编译它们。一旦主依赖编译之后,然后就编译主目标(这是通过make命令传入的)。
现在,假设你对某个源文件进行了修改,你再次执行make命令,它将只编译与该源文件相关的目标文件,因此,编译完最终的可执行文件节省了大量的时间。
Make命令实例
下面是本文所使用的测试环境:
OS——Ubunut13.04 Shell——Bash4.2.45 Application——GNUMake3.81
下面是工程的内容:
$ls anotherTest.cMakefiletest.ctest.h
下面是Makefile的内容:
all:test test:test.oanotherTest.o gcc-Walltest.oanotherTest.o-otest test.o:test.c gcc-c-Walltest.c anotherTest.o:anotherTest.c gcc-c-WallanotherTest.c clean: rm-rf*.otest
现在我们来看Linux下一些make命令应用的实例:
1.一个简单的例子
为了编译整个工程,你可以简单的使用make或者在make命令后带上目标all。
$make gcc-c-Walltest.c gcc-c-WallanotherTest.c gcc-Walltest.oanotherTest.o-otest
你能看到make命令第一次创建的依赖以及实际的目标。
如果你再次查看目录内容,里面多了一些.o文件和执行文件:
$ls anotherTest.canotherTest.oMakefiletesttest.ctest.htest.o
现在,假设你对test.c文件做了一些修改,重新使用make编译工程:
$make gcc-c-Walltest.c gcc-Walltest.oanotherTest.o-otest
你可以看到只有test.o重新编译了,然而另一个Test.o没有重新编译。
现在清理所有的目标文件和可执行文件test,你可以使用目标clean:
$makeclean rm-rf*.otest $ls anotherTest.cMakefiletest.ctest.h
你可以看到所有的.o文件和执行文件test都被删除了。
2.通过-B选项让所有目标总是重新建立
到目前为止,你可能注意到make命令不会编译那些自从上次编译之后就没有更改的文件,但是,如果你想覆盖make这种默认的行为,你可以使用-B选项。
下面是个例子:
$make make:Nothingtobedonefor`all'. $make-B gcc-c-Walltest.c gcc-c-WallanotherTest.c gcc-Walltest.oanotherTest.o-otest
你可以看到尽管make命令不会编译任何文件,然而make-B会强制编译所有的目标文件以及最终的执行文件。
3.使用-d选项打印调试信息
如果你想知道make执行时实际做了什么,使用-d选项。
这是一个例子:
$make-d|more GNUMake3.81 Copyright(C)2006FreeSoftwareFoundation,Inc. Thisisfreesoftware;seethesourceforcopyingconditions. ThereisNOwarranty;notevenforMERCHANTABILITYorFITNESSFORA PARTICULARPURPOSE. Thisprogrambuiltforx86_64-pc-linux-gnu Readingmakefiles… Readingmakefile`Makefile'… Updatingmakefiles…. Consideringtargetfile`Makefile'. Lookingforanimplicitrulefor`Makefile'. Tryingpatternrulewithstem`Makefile'. Tryingimplicitprerequisite`Makefile.o'. Tryingpatternrulewithstem`Makefile'. Tryingimplicitprerequisite`Makefile.c'. Tryingpatternrulewithstem`Makefile'. Tryingimplicitprerequisite`Makefile.cc'. Tryingpatternrulewithstem`Makefile'. Tryingimplicitprerequisite`Makefile.C'. Tryingpatternrulewithstem`Makefile'. Tryingimplicitprerequisite`Makefile.cpp'. Tryingpatternrulewithstem`Makefile'. --More--
这是很长的输出,你也看到我使用了more命令来一页一页显示输出。
4.使用-C选项改变目录
你可以为make命令提供不同的目录路径,在寻找Makefile之前会切换目录的。
这是一个目录,假设你就在当前目录下:
$ls filefile2frndfrnd1.cpplog1.txtlog3.txtlog5.txt file1filenamewithspacesfrnd1frnd.cpplog2.txtlog4.txt
但是你想运行的make命令的Makefile文件保存在../make-dir/目录下,你可以这样做:
$make-C../make-dir/ make:Enteringdirectory`/home/himanshu/practice/make-dir' make:Nothingtobedonefor`all'. make:Leavingdirectory`/home/himanshu/practice/make-dir
你能看到make命令首先切到特定的目录下,在那执行,然后再切换回来。
5.通过-f选项将其它文件看作Makefile
如果你想将重命名Makefile文件,比如取名为my_makefile或者其它的名字,我们想让make将它也当成Makefile,可以使用-f选项。
make-fmy_makefile
通过这种方法,make命令会选择扫描my_makefile来代替Makefile。
以上就是本文的详细内容,希望对大家的学习有所帮助。