linux 如何用make命令带参数详解!什么意思?

摘要: linux 如何用make命令带参数详解!什么意思?,make命令,linux运维,好用的linux运维指南,您值得拥有

  在linux环境下的工作,免不了需要经常编译C/C++源代码,所以make命令是我们经常都会用到的。当然make工具不一定针对C代码,它也可以维护其他各种代码,详见:man make

  make命令是GNU的工程化编译工具,用于编译众多相互关联的源代码问价,以实现工程化的管理,提高开发效率。

  语法

  make(选项)(参数)

  选项

  -f:指定“makefile”文件;

  -i:忽略命令执行返回的出错信息;

  -s:沉默模式,在执行之前不输出相应的命令行信息;

  -r:禁止使用build-in规则;

  -n:非执行模式,输出所有执行命令,但并不执行;

  -t:更新目标文件;

  -q:make操作将根据目标文件是否已经更新返回"0"或非"0"的状态信息;

  -p:输出所有宏定义和目标文件描述;

  -d:Debug模式,输出有关文件和检测时间的详细信息。

  Linux下常用选项与Unix系统中稍有不同,下面是不同的部分:

  -c dir:在读取 makefile 之前改变到指定的目录dir;

  -I dir:当包含其他 makefile文件时,利用该选项指定搜索目录;

  -h:help文挡,显示所有的make选项;

  -w:在处理 makefile 之前和之后,都显示工作目录。

  参数

  目标:指定编译目标。

  

Make 命令实例

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

  OS —— Ubunut 13.04

  Shell —— Bash 4.2.45

  Application —— GNU Make 3.81

  下面是工程的内容:

  $ 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 命令后带上目标 all。

  $ make

  gcc -c -Wall test.c

  gcc -c -Wall anotherTest.c

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

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

  如果你再次查看目录内容,里面多了一些 .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 APARTICULAR 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-dir'

  make: 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。
 

  make命令什么意思

  Make的概念:

  Make这个词,英语的意思是"制作"。Make命令直接用了这个意思,就是要做出某个文件。比如,要做出文件a.txt,就可以执行下面的命令。

  代码如下:

  $ make a.txt

  但是,如果你真的输入这条命令,它并不会起作用。因为Make命令本身并不知道,如何做出a.txt,需要有人告诉它,如何调用其他命令完成这个目标。

  比如,假设文件 a.txt 依赖于 b.txt 和 c.txt ,是后面两个文件连接(cat命令)的产物。那么,make 需要知道下面的规则。

  代码如下:

  a.txt: b.txt c.txtcat b.txt c.txt > a.txt

  也就是说,make a.txt 这条命令的背后,实际上分成两步:第一步,确认 b.txt 和 c.txt 必须已经存在,第二步使用 cat 命令 将这个两个文件合并,输出为新文件。

  像这样的规则,都写在一个叫做Makefile的文件中,Make命令依赖这个文件进行构建。Makefile文件也可以写为makefile, 或者用命令行参数指定为其他文件名。

  代码如下:

  $ make -f rules.txt# 或者$ make --file=rules.txt

  上面代码指定make命令依据rules.txt文件中的规则,进行构建。

  总之,make只是一个根据指定的Shell命令进行构建的工具。它的规则很简单,你规定要构建哪个文件、它依赖哪些源文件,当那些文件有变动时,如何重新构建它。

  make,就是编译,大多数的源代码包都经过这一步进行编译(但有些perl或python编写的软件需要调用perl或python来进行编译)。如果 在 make 过程中出现 error ,你就要记下错误代码,然后你可以向开发者提交 bugreport(一般在 INSTALL 里有提交地址),或者你的系统少了一些依赖库等,这些都要自己仔细研究错误代码。

本文由 帝一博客 原创发布。用户在本站发布的原创内容(包括但不仅限于回答、文章和评论),著作权均归用户本人所有。独家文章转载,请联系邮箱:17762131@qq.com。获得授权后,须注明本文地址: https://bubukou.com/linuxyunwei/1896.html

网友留言评论

0条评论