Was ist Makefile unter Linux?
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.
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
Manchmal gibt es mehrere Ziele im Makefile, aber das Makefile legt das erste Ziel als ultimatives Ziel fest
. 5. ArbeitsprinzipGenerierung 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.
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
-fhinzufügen, wie zum Beispiel:
make -f Makefile_demo
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 imMakefile 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.oBesonders 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!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Die wichtigsten Unterschiede zwischen CentOS und Ubuntu sind: Ursprung (CentOS stammt von Red Hat, für Unternehmen; Ubuntu stammt aus Debian, für Einzelpersonen), Packungsmanagement (CentOS verwendet yum, konzentriert sich auf Stabilität; Ubuntu verwendet apt, für hohe Aktualisierungsfrequenz), Support Cycle (Centos) (CENTOS bieten 10 Jahre. Tutorials und Dokumente), Verwendungen (CentOS ist auf Server voreingenommen, Ubuntu ist für Server und Desktops geeignet). Weitere Unterschiede sind die Einfachheit der Installation (CentOS ist dünn)

CentOS -Installationsschritte: Laden Sie das ISO -Bild herunter und verbrennen Sie bootfähige Medien. Starten und wählen Sie die Installationsquelle; Wählen Sie das Layout der Sprache und Tastatur aus. Konfigurieren Sie das Netzwerk; Partition die Festplatte; Setzen Sie die Systemuhr; Erstellen Sie den Root -Benutzer; Wählen Sie das Softwarepaket aus; Starten Sie die Installation; Starten Sie nach Abschluss der Installation von der Festplatte neu und starten Sie von der Festplatte.

CentOS wird 2024 geschlossen, da seine stromaufwärts gelegene Verteilung RHEL 8 geschlossen wurde. Diese Abschaltung wirkt sich auf das CentOS 8 -System aus und verhindert, dass es weiterhin Aktualisierungen erhalten. Benutzer sollten eine Migration planen, und empfohlene Optionen umfassen CentOS Stream, Almalinux und Rocky Linux, um das System sicher und stabil zu halten.

Docker verwendet Linux -Kernel -Funktionen, um eine effiziente und isolierte Anwendungsumgebung zu bieten. Sein Arbeitsprinzip lautet wie folgt: 1. Der Spiegel wird als schreibgeschützte Vorlage verwendet, die alles enthält, was Sie für die Ausführung der Anwendung benötigen. 2. Das Union File System (UnionFS) stapelt mehrere Dateisysteme, speichert nur die Unterschiede, speichert Platz und beschleunigt. 3. Der Daemon verwaltet die Spiegel und Container, und der Kunde verwendet sie für die Interaktion. 4. Namespaces und CGroups implementieren Container -Isolation und Ressourcenbeschränkungen; 5. Mehrere Netzwerkmodi unterstützen die Containerverbindung. Nur wenn Sie diese Kernkonzepte verstehen, können Sie Docker besser nutzen.

CentOS wurde eingestellt, Alternativen umfassen: 1. Rocky Linux (beste Kompatibilität); 2. Almalinux (kompatibel mit CentOS); 3. Ubuntu Server (Konfiguration erforderlich); 4. Red Hat Enterprise Linux (kommerzielle Version, bezahlte Lizenz); 5. Oracle Linux (kompatibel mit CentOS und RHEL). Bei der Migration sind Überlegungen: Kompatibilität, Verfügbarkeit, Unterstützung, Kosten und Unterstützung in der Gemeinde.

Nachdem CentOS gestoppt wurde, können Benutzer die folgenden Maßnahmen ergreifen, um sich damit zu befassen: Wählen Sie eine kompatible Verteilung aus: wie Almalinux, Rocky Linux und CentOS Stream. Migrieren Sie auf kommerzielle Verteilungen: wie Red Hat Enterprise Linux, Oracle Linux. Upgrade auf CentOS 9 Stream: Rolling Distribution und bietet die neueste Technologie. Wählen Sie andere Linux -Verteilungen aus: wie Ubuntu, Debian. Bewerten Sie andere Optionen wie Container, virtuelle Maschinen oder Cloud -Plattformen.

Wie benutze ich Docker Desktop? Docker Desktop ist ein Werkzeug zum Ausführen von Docker -Containern auf lokalen Maschinen. Zu den zu verwendenden Schritten gehören: 1.. Docker Desktop installieren; 2. Start Docker Desktop; 3.. Erstellen Sie das Docker -Bild (mit Dockerfile); 4. Build Docker Image (mit Docker Build); 5. Docker -Container ausführen (mit Docker Run).

VS Code system requirements: Operating system: Windows 10 and above, macOS 10.12 and above, Linux distribution processor: minimum 1.6 GHz, recommended 2.0 GHz and above memory: minimum 512 MB, recommended 4 GB and above storage space: minimum 250 MB, recommended 1 GB and above other requirements: stable network connection, Xorg/Wayland (Linux)
