Heim  >  Artikel  >  Betrieb und Instandhaltung  >  Was ist Makefile unter Linux?

Was ist Makefile unter Linux?

青灯夜游
青灯夜游Original
2021-11-26 14:02:444771Durchsuche

Unter Linux ist Makefile die Kompilierungsregel einer Projektdatei, die die Kompilierungs- und Verknüpfungsregeln des gesamten Projekts beschreibt. Dazu gehört, welche Dateien kompiliert werden müssen, welche Dateien nicht kompiliert werden müssen und welche Dateien kompiliert werden müssen zuerst kompiliert werden und welche Dateien später kompiliert werden müssen Kompilierung, welche Dateien neu erstellt werden müssen usw.

Was ist Makefile unter Linux?

Die Betriebsumgebung dieses Tutorials: Linux5.9.8-System, Dell G3-Computer.

1. Was ist Makefile? Makefile kann man sich einfach als die Kompilierungsregeln einer Projektdatei vorstellen, die die Kompilierungs- und Verknüpfungsregeln des gesamten Projekts beschreiben.

Ein Projekt auf Unternehmensebene verfügt normalerweise über viele Quelldateien, die manchmal nach Funktionen, Typen und Modulen in verschiedene Verzeichnisse unterteilt sind. Manchmal werden die Quellcodes mehrerer Programme in einem Verzeichnis gespeichert.

Makefle wurde geboren, um das Problem zu lösen, wie einige der oben genannten Codes kompiliert werden sollen. Es definiert eine Reihe von Regeln, die bestimmen, welche Dateien zuerst kompiliert werden sollen, welche Dateien später kompiliert werden sollen und welche Dateien neu kompiliert werden sollen.

Alles, was zum Kompilieren des gesamten Projekts gehört, kann im Makefile beschrieben werden. Mit anderen Worten: Makefile kann die Kompilierung unserer Projektprojekte automatisieren, ohne jedes Mal eine Reihe von Quelldateien und Parametern manuell eingeben zu müssen. Der Vorteil von

Makefile besteht darin, dass es eine „autonome Kompilierung“ erreichen kann. Das gesamte Projekt benötigt normalerweise nur einen

make

-Befehl, um die Kompilierung, Verknüpfung und noch komplexere Funktionen abzuschließen. Man kann sagen, dass jedes Linux-Quellprogramm mit einem Makefile geliefert wird. 2. Vorteile von Makefile

    Verwalten Sie die Kompilierung von Code, entscheiden Sie, welche Dateien kompiliert werden sollen, welche Kompilierungsreihenfolge erforderlich ist und ob eine Neukompilierung erforderlich ist.
  • Sparen Sie Kompilierungszeit. Wenn sich die Datei ändert, kompilieren Sie diese Datei einfach neu, ohne das gesamte Projekt neu zu kompilieren
  • Ein für alle Mal. Makefiles müssen in der Regel nur einmal geschrieben werden und müssen später nicht allzu viel geändert werden. 3. Benennungsregeln Makefile, da hierdurch zuerst das Makefile angezeigt wird.
  • Wenn Sie das Makefile mit einem anderen Namen benennen, z. B. Makefile_demo, ist dies ebenfalls zulässig, bei der Verwendung sollte jedoch die folgende Methode verwendet werden:

  • make -f Makefile_demo

4 Grundregeln

Die Grundregeln von Makefile sind: Ziel: Abhängigkeit

             -- > Ziele aus Abhängigkeitsdateien generieren Datei bedeutet

Tab -->

Jede Regel muss mit Tab beginnen

, Leerzeichen sind nicht erlaubt

Zum Beispiel schreiben wir oft gcc test.c -o test, mit Makefile ist es möglich geschrieben werden als:

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

Unter diesen ist Test in der ersten Zeile das zu generierende Ziel, test.c ist die Abhängigkeit und die zweite Zeile ist die Regel zum Generieren von Test aus test.c.

Manchmal gibt es mehrere Ziele im Makefile, aber das Makefile legt das erste Ziel als ultimatives Ziel fest

.

5. Arbeitsprinzip

Generierung des Ziels:

a. Überprüfen Sie, ob die Abhängigkeitsdatei in der Regel vorhanden ist. b Abhängigkeitsdatei.

Im Bild oben lautet die Regel zum Generieren des Rechners beispielsweise gcc main.o add.o sub.o mul.o p.o -o. Makefil prüft zuerst main.o, add.o, sub. o, mul. Existiert o, p.o? Wenn nicht, wird nach Regeln gesucht, um die Abhängigkeitsdatei zu generieren.

Wenn beispielsweise die Abhängigkeit main.o fehlt, prüft das Makefile unten, ob es Regeln zum Generieren von main.o gibt. Wenn es feststellt, dass die Regel gcc main.c -o main.o main.o generieren kann, verwendet es diese Regel, um main.o zu generieren, und generiert dann den ultimativen Zielrechner. Der gesamte Prozess besteht darin, Abhängigkeiten nach unten zu finden und dann Befehle nach oben auszuführen, um das endgültige Ziel zu generieren.

Zielaktualisierung:

a. Wenn eine Abhängigkeit aktualisiert wird, generieren Sie das Ziel neu.

b.

Was ist Makefile unter Linux?Wenn beispielsweise main.c geändert wird, wird das Ziel main.o neu kompiliert. Wenn main.o aktualisiert wird, wird auch der ultimative Zielrechner neu kompiliert. Auch die Aktualisierung anderer Dateien erfolgt analog.

6. Befehlsausführung

make:

Verwenden Sie diesen Befehl, um Zieldateien nach vorgegebenen Regeln zu generieren. Wenn der Name des Makefiles nicht Makefile oder Makefile ist, sollten Sie die Option

-f

hinzufügen, wie zum Beispiel:

make -f Makefile_demo

Was ist Makefile unter Linux?make clean:

Löschen Sie die Zwischendateien (.o-Dateien) und endgültigen Zieldateien, die während des Kompilierungsprozesses generiert wurden.

Wenn im aktuellen Verzeichnis eine Datei mit dem Namen „clean“ vorhanden ist, wird dieser Befehl nicht ausgeführt.

​ -->Lösung: Pseudo-Zielanweisung: .PHONY:clean

Spezielle Symbole:

-: Zeigt an, dass auch dann, wenn während der Ausführung dieses Befehls ein Fehler auftritt, nachfolgende Befehle weiterhin ausgeführt werden hingerichtet. Beispiel:

-rm a.o build/

@: gibt an, dass der Befehl nur ohne Echo ausgeführt wird. Wenn eine allgemeine Regel ausgeführt wird, wird die ausgeführte Regel auf dem Terminal gedruckt. Nach dem Hinzufügen dieses Symbols wird nur der Befehl ausgeführt und die ausgeführte Regel wird nicht wiederholt. Zum Beispiel:

@echo $(SOURCE)

7. Gewöhnliche Variablen

Variablendefinition und -zuweisung:

Variablen können direkt durch Zuweisen von Werten definiert werden, wie zum Beispiel:

INCLUDE = ./include/

Variablenwert:

Setzen Sie ihn in Klammern und fügen Sie ein Dollarzeichen hinzu, z. B.:

FOO = $(OBJ)

In das System integrierte Variablen:

Normalerweise alle Großbuchstaben, z. B. CC, PWD, CFLAG usw.

Einige haben Standardwerte, andere nicht. Zum Beispiel die häufigsten:

CPPFLAGS: vom Präprozessor benötigte Optionen wie: -I

CFLAGS: während der Kompilierung verwendete Parameter –Wall –g -c

LDFLAGS: von der Linkbibliothek verwendete Optionen –L -l

Der Standardwert von Variablen kann geändert werden. Der Standardwert von CC ist beispielsweise cc, er kann jedoch in gcc geändert werden: CC=gcc

8. Häufig verwendete automatische Variablen:

Makefile bietet viele automatische Variablen, aber die folgenden drei werden häufig verwendet. Diese automatischen Variablen können nur in Befehlen in Regeln verwendet werden und können nicht anderswo verwendet werden.

$@ --> Das Ziel in der Regel

$$^ --> app: main.c func1.c fun2.c

 gcc $^ - o $@

Unter ihnen: $^ repräsentiert main.c func1.c fun2.c, $

Musterregeln:

Musterregeln bestehen darin, % in den Ziel- und Abhängigkeitsbedingungen zu verwenden, um die entsprechenden Dateien abzugleichen. Im Verzeichnis befinden sich beispielsweise drei Dateien: main.c, func1.c und func2.c. Für diese drei Die Kompilierung der Datei kann durch eine Regel abgeschlossen werden:

%.o:%.c

$(CC) –c $

Diese Musterregel bedeutet:

main. o wird von main.c generiert,

  func1.o wird von func1.c generiert,

  func2.o wird von func2.c generiert

Dies ist die Rolle von Musterregeln, die alle Dateien im Verzeichnis unter abgleichen können einmal.

9. Funktionen

makefile bietet uns auch eine große Anzahl von Funktionen. Die folgenden zwei Funktionen werden ebenfalls häufig verwendet. Es ist zu beachten, dass alle Funktionen im

Makefile einen Rückgabewert

haben müssen. Nehmen wir im folgenden Beispiel an, dass sich im Verzeichnis drei Dateien main.c, func1.c und func2.c befinden.

Wildcard:

wird verwendet, um Dateien eines bestimmten Typs in einem bestimmten Verzeichnis zu finden. Die folgenden Parameter sind beispielsweise Verzeichnis + Dateityp:

src = $(wildcard ./src/*.c)

Bedeutet: Finden Sie alle Dateien mit dem Suffix .c im Verzeichnis ./src und weisen Sie sie der Variablen src zu.

Nach Abschluss der Befehlsausführung lautet der Wert von src: main.c func1.c fun2.c.

patsubst:

Eine passende Ersetzung, wie im folgenden Beispiel, wird verwendet, um alle Dateien mit der Endung .c im src-Verzeichnis zu finden, sie durch .o-Dateien zu ersetzen und sie obj zuzuweisen.

obj = $(patsubst %.c ,%.o ,$(src))

Ersetzen Sie alle Dateien mit dem Suffix .c in der src-Variablen durch .o.

Nachdem der Befehl ausgeführt wurde, lautet der Wert von obj main.o func1.o func2.o

Besonders wenn Sie alle .o-Dateien im obj-Verzeichnis ablegen möchten, können Sie die folgende Methode verwenden:

ob = $(patsubst . /src/%.c, ./obj/%.o, $(src))

Verwandte Empfehlungen: „

Linux Video Tutorial

Das obige ist der detaillierte Inhalt vonWas ist Makefile unter Linux?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn