La commande de compilation du système Linux est "Make". Dans les systèmes Linux, make est une commande de compilation très importante. Les administrateurs l'utilisent pour compiler et installer de nombreux outils open source via la ligne de commande. Les programmeurs l'utilisent pour gérer les problèmes de compilation de leurs projets volumineux et complexes. make est utilisé pour gérer les tâches de compilation automatique pour les grands programmes, déterminer automatiquement qu'une certaine partie du programme doit être recompilée et émettre des instructions de compilation.
L'environnement d'exploitation de ce tutoriel : système linux7.3, ordinateur Dell G3.
La commande make sous Linux est l'une des commandes les plus fréquemment utilisées par les administrateurs système et les programmeurs. Les administrateurs l'utilisent pour compiler et installer de nombreux outils open source via la ligne de commande, et les programmeurs l'utilisent pour gérer les problèmes de compilation de leurs projets volumineux et complexes. Dans cet article, nous utiliserons quelques exemples pour discuter du mécanisme de fonctionnement derrière la commande make.
make est un programme utilitaire pour les systèmes Linux. Il est utilisé pour gérer les tâches de compilation automatique pour les gros programmes, déterminer automatiquement qu'une certaine partie du programme doit être recompilée et émettre des instructions de compilation. Cependant, nous l’utilisons le plus souvent dans la compilation de programmes en langage C. Cependant, make n'est pas limité à un langage spécifique. Make peut être utilisé dans n'importe quel langage pouvant exécuter le compilateur via une commande shell. De plus, vous pouvez même utiliser make pour décrire toute tâche de construction dans laquelle un fichier doit être automatiquement mis à jour après la modification des fichiers dont il dépend.
Pour ceux qui ne connaissent pas les mécanismes derrière cela, la commande make accepte les cibles tout comme les arguments de ligne de commande. Ces objectifs sont généralement stockés dans des fichiers spéciaux nommés « Makefile », et les fichiers contiennent également des opérations correspondant aux objectifs. Pour plus d'informations, lisez cette série d'articles sur le fonctionnement des Makefiles.
Lorsque la commande make est exécutée pour la première fois, elle analyse le Makefile pour trouver la cible et ses dépendances. Si ces dépendances sont elles-mêmes des cibles, continuez à analyser le Makefile pour rechercher ces dépendances afin d'établir leurs dépendances, puis compilez-les. Une fois les dépendances principales compilées, la cible principale est compilée (qui est transmise via la commande make).
Maintenant, en supposant que vous avez modifié un certain fichier source et que vous exécutez à nouveau la commande make, elle ne compilera que les fichiers cibles liés au fichier source. Par conséquent, la compilation du fichier exécutable final permet de gagner beaucoup de temps.
Voici l'environnement de test utilisé dans cet article :
OS —— Ubunut 13.04 Shell —— Bash 4.2.45 Application —— GNU Make 3.81
Ce qui suit est le contenu du projet :
$ ls anotherTest.c Makefile test.c test.h
Ce qui suit est le contenu du Makefile :
all: test test: test.o anotherTest.o gcc -Wall test.o anotherTest.o -o testtest.o: test.c gcc -c -Wall test.c anotherTest.o: anotherTest.c gcc -c -Wall anotherTest.c clean: rm -rf *.o test
Regardons maintenant Linux. Voici quelques exemples d'applications de commandes make :
Pour compiler l'intégralité du projet, vous pouvez simplement utiliser make
ou ajouter la cible. tout après la commande make
. 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 都被删除了。
到目前为止,你可能注意到 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
会强制编译所有的目标文件以及最终的执行文件。
如果你想知道 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
$ 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 -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 -f my_makefile
clean
:🎜🎜rrreee🎜🎜Vous pouvez voir que tous les fichiers .o et le test des fichiers exécutables ont été supprimés. 🎜🎜🎜2. Faites en sorte que toutes les cibles soient toujours reconstruites avec l'option -B🎜🎜🎜À présent, vous avez peut-être remarqué que la commande make ne compile pas les fichiers qui n'ont pas changé depuis la dernière compilation, cependant, si vous le souhaitez. overwrite Pour ce comportement par défaut de make, vous pouvez utiliser l'option -B. 🎜🎜Voici un exemple : 🎜🎜rrreee🎜🎜Vous pouvez voir que même si la commande make ne compilera aucun fichier, make -B
forcera la compilation de tous les fichiers cibles et du fichier exécutable final. 🎜🎜🎜3. Utilisez l'option -d pour imprimer les informations de débogage 🎜🎜🎜 Si vous voulez savoir ce que make fait réellement lorsqu'il est exécuté, utilisez l'option -d. 🎜🎜Voici un exemple : 🎜🎜rrreee🎜🎜C'est une sortie très longue, vous avez également vu que j'ai utilisé la commande more
pour afficher la sortie page par page. 🎜🎜🎜4. Utilisez l'option -C pour changer de répertoire 🎜🎜🎜Vous pouvez fournir un chemin de répertoire différent pour la commande make, et le répertoire sera changé avant de rechercher le Makefile. 🎜🎜Il s'agit d'un répertoire, en supposant que vous soyez dans le répertoire courant :🎜rrreee🎜Mais le fichier Makefile de la commande make que vous souhaitez exécuter est enregistré dans le répertoire ../make-dir/, vous pouvez faire ceci :🎜🎜 rrreee🎜你能看到 make 命令首先切到特定的目录下,在那执行,然后再切换回来。
如果你想将重命名 Makefile 文件,比如取名为 my_makefile 或者其它的名字,我们想让 make 将它也当成 Makefile,可以使用 -f 选项。
make -f my_makefile
通过这种方法,make 命令会选择扫描 my_makefile 来代替 Makefile。
相关推荐:《Linux视频教程》
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!