


Qu'est-ce que le makefile sous Linux
Sous Linux, makefile est la règle de compilation d'un fichier de projet, qui décrit les règles de compilation et de liaison de l'ensemble du projet ; elle inclut quels fichiers doivent être compilés, quels fichiers n'ont pas besoin d'être compilés, quels fichiers doivent être compilés. compilé en premier et quels fichiers doivent être compilés plus tard Compilation, quels fichiers doivent être reconstruits, etc.
L'environnement d'exploitation de ce tutoriel : système linux5.9.8, ordinateur Dell G3.
1. Qu'est-ce que Makefile
Makefile peut être simplement considéré comme les règles de compilation d'un fichier de projet, décrivant les règles de compilation et de liaison de l'ensemble du projet.
Un projet au niveau de l'entreprise comporte généralement de nombreux fichiers sources, qui sont parfois divisés en différents répertoires selon les fonctions, les types et les modules. Parfois, les codes sources de plusieurs programmes sont stockés dans un seul répertoire.
Makefle est né pour résoudre le problème de la compilation de certains des codes ci-dessus. Il définit un ensemble de règles qui déterminent quels fichiers doivent être compilés en premier, quels fichiers doivent être compilés plus tard et quels fichiers doivent être recompilés.
Tout ce qui est impliqué dans la compilation de l'ensemble du projet peut être décrit dans le Makefile. En d’autres termes, Makefile peut automatiser la compilation de nos projets sans avoir à saisir manuellement un tas de fichiers sources et de paramètres à chaque fois. L'avantage de
Makefile est qu'il peut réaliser une "compilation autonome". L'ensemble du projet n'a généralement besoin que d'une seule commande make pour terminer la compilation, la liaison et des fonctions encore plus complexes. On peut dire que tout programme source Linux est livré avec un Makefile.
2. Avantages de Makefile
Gérez la compilation du code, décidez quels fichiers compiler, l'ordre de compilation et si une recompilation est nécessaire ;
Gagnez du temps de compilation ; Si le fichier change, recompilez simplement ce fichier sans recompiler l'intégralité du projet
Une fois pour toutes ; Les Makefiles ne doivent généralement être écrits qu’une seule fois et n’ont pas besoin d’être trop modifiés par la suite.
3. Règles de dénomination
De manière générale, il est acceptable de nommer le Makefile comme Makefile ou makefile, mais les noms de nombreux fichiers sources sont en minuscules, donc davantage de programmeurs utilisent le nom du Makefile, car cela affichera d'abord le Makefile.
Si vous nommez le Makefile avec un autre nom, tel que Makefile_demo, cela est également autorisé, mais la méthode suivante doit être utilisée lors de son utilisation :
make -f Makefile_demo
Règles de base
Les règles de base de Makefile. sont :
Cible :Dépendance
(onglet) Règles
Cible--> Dépendances--> Certains fichiers nécessaires pour générer la cible
Règles-- > Générer des cibles à partir des fichiers de dépendance Fichier signifie
tab -->
Chaque règle doit commencer par tab , les espaces ne sont pas autorisésPar exemple, nous écrivons souvent gcc test.c -o test, en utilisant Makefile, cela peut s'écrire comme :
test: test.c gcc test.c -o test
Parmi eux, Test dans la première ligne est la cible à générer, test.c est la dépendance et la deuxième ligne est la règle pour générer un test à partir de test.c.
Parfois, il y a plusieurs objectifs dans le Makefile, mais le Makefile
définira le premier objectif comme objectif ultime. 5. Principe de fonctionnement
Génération de la cible :a Vérifiez si le fichier de dépendances dans la règle existe
b Si le fichier de dépendances n'existe pas, recherchez s'il existe une règle pour générer la règle. fichier de dépendance.
Par exemple, dans l'image ci-dessus, la règle pour générer la calculatrice est gcc main.o add.o sub.o mul.o p.o -o Makefil vérifiera d'abord main.o, add.o, sub. o, mul. Est-ce que o, p.o existe ? Sinon, il recherchera des règles pour générer le fichier de dépendances.
Par exemple, si la dépendance de main.o est manquante, le Makefile regardera ci-dessous pour voir s'il existe des règles pour générer main.o. Lorsqu'il constate que la règle gcc main.c -o main.o peut générer main.o, il utilise cette règle pour générer main.o, puis génère le calculateur d'objectif ultime.
L'ensemble du processus consiste à trouver des dépendances vers le bas, puis à exécuter des commandes vers le haut pour générer l'objectif ultime.
Mise à jour de la cible :a. Vérifiez toutes les dépendances de la cible, régénérez la cible
b Si le fichier cible est postérieur au fichier dépendant, il doit l'être. mis à jour.
Par exemple, si main.c est modifié, la cible main.o sera recompilée. Lorsque main.o sera mis à jour, le calculateur de cible ultime sera également recompilé. La mise à jour des autres fichiers se fait également par analogie.
6. Exécution de la commande
make:Utilisez cette commande pour générer des fichiers cibles selon des règles prédéterminées.
Si le nom du Makefile n'est pas Makefile ou makefile, vous devez ajouter l'option
-f, telle que : make -f Makefile_demo
make clean:Effacez les fichiers intermédiaires (fichiers .o) et les fichiers cibles finaux générés lors du processus de compilation. Si un fichier nommé clean existe dans le répertoire courant, cette commande ne sera pas exécutée. -->Solution : Déclaration pseudo-cible : .PHONY:clean Symboles spéciaux : - : Indique que même si une erreur survient lors de l'exécution de cette commande, les commandes suivantes continueront d'être exécutées . Par exemple : -rm a.o build/ @ : indique que la commande sera uniquement exécutée sans écho. Lorsqu'une règle générale est exécutée, la règle d'exécution sera imprimée sur le terminal. Après avoir ajouté ce symbole, seule la commande sera exécutée et la règle exécutée ne sera pas répercutée. Par exemple : @echo $(SOURCE) Définition et affectation des variables : Les variables peuvent être définies directement en attribuant des valeurs, telles que : INCLUDE = ./include/ Valeur de la variable : Entourez-la de parenthèses et ajoutez un signe dollar, tel que : FOO = $(OBJ) Variables intégrées au système : Habituellement, toutes les lettres majuscules, telles que CC, PWD, CFLAG, etc. Certains ont des valeurs par défaut, d'autres non. Par exemple, les plus courantes : CPPFLAGS : options requises par le préprocesseur telles que : -I CFLAGS : paramètres utilisés lors de la compilation –Wall –g -c LDFLAGS : options utilisées par la bibliothèque de liens –L -l La valeur par défaut des variables peut être modifiée. Par exemple, la valeur par défaut de CC est cc, mais elle peut être modifiée en gcc : CC=gcc Variables automatiques couramment utilisées : Makefile fournit de nombreuses variables automatiques, mais les trois suivantes sont couramment utilisées. Ces variables automatiques ne peuvent être utilisées que dans les commandes des règles et ne peuvent être utilisées ailleurs. $@ --> La cible dans la règle $ La première condition de dépendance dans la règle $^ --> app : main.c func1.c fun2.c gcc $^ - o $@ Parmi eux : $^ représente main.c func1.c fun2.c, $ Les règles de modèle utilisent % dans les conditions de cible et de dépendance pour correspondre aux fichiers correspondants. Par exemple, il y a trois fichiers main.c, func1.c et func2.c dans le répertoire. trois fichiers, La compilation du fichier peut être complétée par une règle : %.o:%.c $(CC) –c $ Cette règle de modèle signifie : main. o est généré par main.c, func1.o est généré par func1.c, func2.o est généré par func2.c C'est le rôle des règles de modèle, qui peuvent faire correspondre tous les fichiers du répertoire à une fois. 9. Fonctions makefile nous fournit également un grand nombre de fonctions. Les deux fonctions suivantes sont également couramment utilisées. Il convient de noter que toutes les fonctions du wildcard : est utilisé pour rechercher des fichiers d'un type spécifié dans un répertoire spécifié. Les paramètres suivants sont le répertoire + le type de fichier, par exemple : src = $(wildcard ./src/*.c) Moyens : Recherchez tous les fichiers avec le suffixe .c dans le répertoire ./src et affectez-les à la variable src. Une fois l'exécution de la commande terminée, la valeur de src est : main.c func1.c fun2.c. Le remplacement correspondant, comme dans l'exemple suivant, est utilisé pour rechercher tous les fichiers se terminant par .c dans le répertoire src, les remplacer par des fichiers .o et les affecter à obj. obj = $(patsubst %.c ,%.o ,$(src)) Remplacez tous les fichiers par le suffixe .c dans la variable src par .o. Une fois la commande exécutée, la valeur de obj est main.o func1.o func2.o Spécialement, si vous souhaitez placer tous les fichiers .o dans le répertoire obj, vous pouvez utiliser la méthode suivante : ob = $(patsubst . /src/%.c, ./obj/%.o, $(src)) Recommandations associées : " "7. Variables ordinaires
8 Variables automatiques
. Dans l'exemple suivant, supposons qu'il y ait trois fichiers main.c, func1.c et func2.c dans le répertoire.
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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Pour permettre aux conteneurs PHP de prendre en charge la construction automatique, le noyau réside dans la configuration du processus d'intégration continue (CI). 1. Utilisez Dockerfile pour définir l'environnement PHP, y compris l'image de base, l'installation d'extension, la gestion de la dépendance et les paramètres d'autorisation; 2. Configurez des outils CI / CD tels que GitLabci et définissez les étapes de construction, de test et de déploiement via le fichier .gitlab-ci.yml pour réaliser une construction, un test et un déploiement automatique; 3. Intégrer des cadres de test tels que PHPUnit pour s'assurer que les tests sont automatiquement exécutés après les modifications du code; 4. Utiliser des stratégies de déploiement automatisées telles que Kubernetes pour définir la configuration de déploiement via le fichier de déploiement.yaml; 5. Optimiser Dockerfile et adopter une construction en plusieurs étapes

WindowsisBetterForbeginnersDuetOeaseOfuse, couresethardwarecompatibilité, andsupportformaintreamsoftwarelikemicrosoftofficeandadoBeapps.2.LinuxoutPerformSwindowSonolderorlow-resourcehardwarewithfasterboottimes, lowersystemReoluments, andlessbloat.3.li, LowersystemRerements, andlessbloat.

La construction d'un environnement de conteneur de tâches PHP indépendant peut être implémentée via Docker. Les étapes spécifiques sont les suivantes: 1. Installez Docker et DockerCose comme base; 2. Créez un répertoire indépendant pour stocker les fichiers Dockerfile et Crontab; 3. Écrivez Dockerfile pour définir l'environnement PHPCLI et installer Cron et les extensions nécessaires; 4. Écrivez un fichier crontab pour définir les tâches de synchronisation; 5. Écrivez un répertoire de script Docker-Compose.yml et configurer les variables d'environnement; 6. Démarrez le conteneur et vérifiez le journal. Par rapport à l'exécution de tâches de synchronisation dans des conteneurs Web, les conteneurs indépendants présentent les avantages de l'isolement des ressources, de l'environnement pur, de la forte stabilité et de l'expansion facile. Pour assurer la journalisation et la capture d'erreur

Il existe trois façons principales d'installer un logiciel sur Linux: 1. Utilisez un gestionnaire de packages, tel que APT, DNF ou PACMAN, puis exécutez la commande d'installation après la mise à jour de la source, telle que SudoaptiNinStallCurl; 2. Pour les fichiers .deb ou .rpm, utilisez des commandes DPKG ou RPM pour installer et réparer les dépendances en cas de besoin; 3. Utilisez Snap ou FlatPak pour installer des applications sur des plates-formes, telles que le nom du logiciel Sudosnapinstall, qui convient aux utilisateurs qui poursuivent les mises à jour de version. Il est recommandé d'utiliser le propre gestionnaire de packages du système pour une meilleure compatibilité et des performances.

CronisUsedForpreciseScheduLingOnalways-Asystèmes, tandis que les éventualités de plus en plus

Choosepop! _OS, Ubuntu, Nobaralinux, OrarchlinuxForoptimalgaming Performance withinmimaloverhead.2.Installofficialnvidiapropriétarydriversfornvidiagpus, assurept-t-to-datememesaandkernerserforamdindelgpus.3,EBablePheperformAlect

Linux convient à l'ancien matériel, a une haute sécurité et est personnalisable, mais a une compatibilité logicielle faible; Le logiciel Windows est riche et facile à utiliser, mais a une utilisation élevée des ressources. 1. En termes de performances, Linux est léger et efficace, adapté aux anciens appareils; Windows a des exigences matérielles élevées. 2. En termes de logiciels, Windows a une compatibilité plus large, en particulier les outils et les jeux professionnels; Linux doit utiliser des outils pour exécuter certains logiciels. 3. En termes de sécurité, la gestion des autorisations Linux est plus stricte et les mises à jour sont pratiques; Bien que Windows soit protégé, il est toujours vulnérable aux attaques. 4. En termes de difficulté d'utilisation, la courbe d'apprentissage Linux est raide; L'opération Windows est intuitive. Choisissez en fonction des exigences: choisissez Linux avec les performances et la sécurité, et choisissez Windows avec compatibilité et facilité d'utilisation.

TimesYnchronization est de la réception de la fiabilité et de la sécurité et de la sécurité de la conscience en cours de réélecause de la sécurité, de la sécurité, des insignes infiasquesdTasks, et dedistributedSystemErrors; 1.CheckntPstatususingTimeDatectlStatustOronFirmSynchronizationAndServiceActivity; 2 2; 2 2; 2 2; 2 2; 2; 2 2; 2;
