Heim >Betrieb und Instandhaltung >Betrieb und Wartung von Linux >So verwenden Sie den Befehl „make' unter Linux
Wie make funktioniert
Für diejenigen, die die Mechanik dahinter nicht kennen: Der Befehl „make“ akzeptiert Ziele genau wie Befehlszeilenargumente. Diese Ziele werden normalerweise in speziellen Dateien namens „Makefiles“ gespeichert, und die Dateien enthalten auch den Zielen entsprechende Operationen. Weitere Informationen finden Sie in dieser Artikelserie zur Funktionsweise von Makefiles.
Wenn der Make-Befehl zum ersten Mal ausgeführt wird, durchsucht er das Makefile, um das Ziel und seine Abhängigkeiten zu finden. Wenn diese Abhängigkeiten selbst Ziele sind, durchsuchen Sie die Makefiles weiter nach diesen Abhängigkeiten, um ihre Abhängigkeiten festzustellen, und kompilieren Sie sie dann. Sobald die Hauptabhängigkeiten kompiliert sind, wird das Hauptziel kompiliert (das über den Befehl „make“ übergeben wird).
Angenommen, Sie haben eine bestimmte Quelldatei geändert und führen den Befehl „make“ erneut aus. Daher wird nach dem Kompilieren nur die Zieldatei kompiliert, die sich auf die Quelldatei bezieht Es. Viel Zeit.
make-Befehlsbeispiel
Das Folgende ist die in diesem Artikel verwendete Testumgebung:
os —— ubunut 13.04 shell —— bash 4.2.45 application —— gnu make 3.81
Das Folgende ist der Inhalt des Projekt: #🎜🎜 #
$ ls anothertest.c makefile test.c test.hDas Folgende ist der Inhalt des Makefiles:
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 testSchauen wir uns nun einige Beispiele für Make-Befehlsanwendungen unter Linux an:
1. Ein einfaches Beispiel
Um das gesamte Projekt zu kompilieren, können Sie einfach make verwenden oder das Ziel all nach dem make-Befehl übergeben.$ make gcc -c -wall test.c gcc -c -wall anothertest.c gcc -wall test.o anothertest.o -o testSie können die Abhängigkeiten sehen, die zum ersten Mal durch den Make-Befehl erstellt wurden, und das tatsächliche Ziel. Wenn Sie den Inhalt des Verzeichnisses noch einmal überprüfen, sind darin noch einige weitere .o-Dateien und ausführbare Dateien enthalten:
$ ls anothertest.c anothertest.o makefile test test.c test.h test.oAngenommen, Sie haben nun einige Änderungen am Test vorgenommen. c-Datei, erneut. Verwenden Sie make, um das Projekt zu kompilieren:
$ make gcc -c -wall test.c gcc -wall test.o anothertest.o -o testSie können sehen, dass nur test.o neu kompiliert wurde, das andere test.o jedoch nicht. Bereinigen Sie nun alle Zieldateien und den Test der ausführbaren Dateien. Sie können die Zielreinigung verwenden:
$ make clean rm -rf *.o test $ ls anothertest.c makefile test.c test.hSie können sehen, dass alle .o-Dateien und der Test der ausführbaren Dateien gelöscht wurden.
2. Übergeben Sie die Option -b, damit alle Ziele immer neu erstellt werden Kompilieren Sie Dateien, die sich seit der letzten Kompilierung nicht geändert haben. Wenn Sie jedoch das Standardverhalten von make überschreiben möchten, können Sie die Option -b verwenden. Das Folgende ist ein Beispiel:
$ 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
Sie können sehen, dass der Befehl make zwar keine Dateien kompiliert, make -b jedoch die Kompilierung aller Objektdateien und der endgültigen Dateien erzwingt ausführbare Datei.
3. Verwenden Sie die Option -d, um Debugging-Informationen auszudrucken.Wenn Sie wissen möchten, was make tatsächlich tut, wenn es ausgeführt wird, verwenden Sie die Option -d. Hier ist ein Beispiel:
$ 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--
Dies ist eine sehr lange Ausgabe. Sie haben auch gesehen, dass ich den Befehl „more“ verwendet habe, um die Ausgabe Seite für Seite anzuzeigen.
4. Verwenden Sie die Option -c, um das Verzeichnis zu ändern.Sie können einen anderen Verzeichnispfad für den Make-Befehl angeben, der wechselt Verzeichnisse, bevor Sie nach dem Makefile von suchen. Dies ist ein Verzeichnis, vorausgesetzt, Sie befinden sich im aktuellen Verzeichnis:
$ ls file file2 frnd frnd1.cpp log1.txt log3.txt log5.txt file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt
Aber die Makefile-Datei des Make-Befehls, den Sie ausführen möchten, wird in ../make gespeichert -dir/ Verzeichnis Als nächstes können Sie Folgendes tun:
$ 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
Sie können sehen, dass der Make-Befehl zuerst in ein bestimmtes Verzeichnis wechselt, es dort ausführt und dann zurückwechselt.
5. Verwenden Sie die Option -f, um andere Dateien als Makefiles zu behandelnWenn Sie die Makefile-Datei umbenennen möchten, geben Sie beispielsweise einen Namen ein Es ist my_makefile Oder ein anderer Name. Wir möchten, dass make es als Makefile behandelt. Sie können die Option -f verwenden. make -f my_makefile
Bei dieser Methode wählt der Befehl „make“, „my_makefile“ anstelle von „makefile“ zu scannen.
Das obige ist der detaillierte Inhalt vonSo verwenden Sie den Befehl „make' unter Linux. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!