Make 命令

Linux 下 make 命令是系统管理员和程序员用的最频繁的命令之一。管理员用它经过命令行来编译和安装不少开源的工具,程序员用它来管理他们大型复杂的项目编译问题。本文咱们将用一些实例来讨论 make 命令背后的工做机制。linux

Make 如何工做的

对于不知道背后机理的人来讲,make 命令像命令行参数同样接收目标。这些目标一般存放在以 “Makefile” 来命名的特殊文件中,同时文件也包含与目标相对应的操做。更多信息,阅读关于 Makefiles 如何工做的系列文章。git

当 make 命令第一次执行时,它扫描 Makefile 找到目标以及其依赖。若是这些依赖自身也是目标,继续为这些依赖扫描 Makefile 创建其依赖关系,而后编译它们。一旦主依赖编译以后,而后就编译主目标(这是经过 make 命令传入的)。程序员

如今,假设你对某个源文件进行了修改,你再次执行 make 命令,它将只编译与该源文件相关的目标文件,所以,编译完最终的可执行文件节省了大量的时间。github

Make 命令实例

下面是本文所使用的测试环境:bash

OS —— Ubunut 13.04
Shell —— Bash 4.2.45
Application —— GNU Make 3.81

下面是工程的内容:ide

$ ls 
anotherTest.c Makefile test.c test.h

下面是 Makefile 的内容:工具

all: test 

test: test.o anotherTest.o 
    gcc -Wall test.o anotherTest.o -o test

test.o: test.c 
    gcc -c -Wall test.c 

anotherTest.o: anotherTest.c 
    gcc -c -Wall anotherTest.c 

clean: 
    rm -rf *.o test

如今咱们来看 Linux 下一些 make 命令应用的实例:测试

1. 一个简单的例子

为了编译整个工程,你能够简单的使用 make 或者在 make 命令后带上目标 allui

$ make 
gcc -c -Wall test.c 
gcc -c -Wall anotherTest.c 
gcc -Wall test.o anotherTest.o -o test

你能看到 make 命令第一次建立的依赖以及实际的目标。spa

若是你再次查看目录内容,里面多了一些 .o 文件和执行文件:

$ ls 
anotherTest.c anotherTest.o Makefile test test.c test.h test.o

如今,假设你对 test.c 文件作了一些修改,从新使用 make 编译工程:

$ make 
gcc -c -Wall test.c 
gcc -Wall test.o anotherTest.o -o test

你能够看到只有 test.o 从新编译了,然而另外一个 Test.o 没有从新编译。

如今清理全部的目标文件和可执行文件 test,你能够使用目标 clean:

$ make clean
rm -rf *.o test

$ ls
anotherTest.c Makefile test.c test.h

你能够看到全部的 .o 文件和执行文件 test 都被删除了。

2. 经过 -B 选项让全部目标老是从新创建

到目前为止,你可能注意到 make 命令不会编译那些自从上次编译以后就没有更改的文件,可是,若是你想覆盖 make 这种默认的行为,你能够使用 -B 选项。

下面是个例子:

$ make
make: Nothing to be done for `all’.

$ make -B
gcc -c -Wall test.c
gcc -c -Wall anotherTest.c
gcc -Wall test.o anotherTest.o -o test

你能够看到尽管 make 命令不会编译任何文件,然而 make -B 会强制编译全部的目标文件以及最终的执行文件。

3. 使用 -d 选项打印调试信息

若是你想知道 make 执行时实际作了什么,使用 -d 选项。

这是一个例子:

$ make -d | more
GNU Make 3.81
Copyright (C) 2006 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.
There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE.

This program built for x86_64-pc-linux-gnu
Reading makefiles…
Reading makefile `Makefile’…
Updating makefiles….
Considering target file `Makefile’.
Looking for an implicit rule for `Makefile’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.o’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.c’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.cc’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.C’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.cpp’.
Trying pattern rule with stem `Makefile’.
--More--

这是很长的输出,你也看到我使用了 more 命令来一页一页显示输出。

4. 使用 -C 选项改变目录

你能够为 make 命令提供不一样的目录路径,在寻找 Makefile 以前会切换目录的。

这是一个目录,假设你就在当前目录下:

$ ls 
file file2 frnd frnd1.cpp log1.txt log3.txt log5.txt
file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt

可是你想运行的 make 命令的 Makefile 文件保存在 ../make-dir/ 目录下,你能够这样作:

$ make -C ../make-dir/ 
make: Entering directory `/home/himanshu/practice/make-dirmake: Nothing to be done for `all’. 
make: Leaving directory `/home/himanshu/practice/make-dir

你能看到 make 命令首先切到特定的目录下,在那执行,而后再切换回来。

5. 经过 -f 选项将其它文件看做 Makefile

若是你想将重命名 Makefile 文件,好比取名为 my_makefile 或者其它的名字,咱们想让 make 将它也当成 Makefile,能够使用 -f 选项。

make -f my_makefile

经过这种方法,make 命令会选择扫描 my_makefile 来代替 Makefile。

相关文章
相关标签/搜索