


Quelle est la connexion entre les bibliothèques et les fichiers d'en-tête sous Linux ?
La connexion entre les bibliothèques et les fichiers d'en-tête sous Linux : il existe des déclarations de fonctions dans les fichiers d'en-tête et des définitions de fonctions implémentées dans les fichiers de bibliothèque ; chaque fonction de la bibliothèque doit être déclarée dans le fichier d'en-tête. Lors de l'écriture d'un programme, vous devez utiliser des fichiers d'en-tête pour fournir des définitions de constantes et des déclarations d'appels aux fonctions système et aux fonctions de bibliothèque ; et une bibliothèque est une collection de fonctions compilées, c'est-à-dire une collection de fichiers cibles ".o". Il est rédigé selon le principe de réutilisabilité et consiste généralement en un ensemble de fonctions interdépendantes pour effectuer une tâche commune.
L'environnement d'exploitation de ce tutoriel : système linux7.3, ordinateur Dell G3.
Dans le code source général de l'application, il y a des déclarations de fonction dans le fichier d'en-tête et les fichiers de bibliothèque implémentent la définition de la fonction ; chaque fonction de la bibliothèque doit être déclarée dans le fichier d'en-tête.
1. Fichiers d'en-tête
Lors de l'écriture d'un programme, nous devons utiliser des fichiers d'en-tête pour fournir des définitions de constantes et des déclarations de fonctions système et d'appels de fonctions de bibliothèque. Ces fichiers d'en-tête se trouvent dans /usr/. inclure
dans. Ces fichiers d'en-tête se trouvent dans des répertoires qui peuvent être automatiquement recherchés par le compilateur, tels que /usr/include/X11 du système X window et /usr/include/c++ de GNU C++. /usr/include
中。这些头文件都位于可以被编译器自动搜索到的目录中,如X视窗系统的/usr/include/X11和GNU C++的/usr/include /c++。
在调用gcc时,可以使用标志-I
来包含保存在子目录或其它非标准位置中的头文件,例如 gcc -I/usr/openwin/include fred.c
2. 库文件
库是一组已经编译好的函数的集合,也就是目标文件.o的集合,是按照可重用的原则编写的,一般由一组互关联的函数组成以执行某项常见任务。
标准linux系统库文件一般存储在/lib
和/usr/lib
目录中。默认情况下GCC的链接程序只搜索标准C语言库,这是一个历史遗留问题。我们必须使库文件名遵守特定的规范并在命令行中加以指定。
库文件总以lib开头,然后指出这是什么库,最后的部分.a代表静态函数库,.so代表共享函数库(即windows下的DLL动态链接库)。
如gcc -o fred fred.c /usr/lib/libm.a
或gcc -o fred fred.c -lm
-L
标志为链接器增加库的搜索路径,如gcc -o x11fred -L /usr/openwin/lib x11fred.c -1X11
2.1 静态库
静态库以.a结尾,也称作归档文件,在生成可执行程序时,静态库文件就被链接进去,生成的可执行文件较大,可以脱离静态库文件运行。
2.1.1 生成方法
首先创建两个源文件fred.c和bill.c
然后用gcc -c
编译生成两个目标文件
然后为这两个函数编写头文件,进行函数声明
然后在main函数中包含头文件并调用其中一个库函数
然后编译main函数并将main.o和之前生成的bill.o链接,可以正确执行
接下来我们生成库文件,用ar归档程序创建归档文件并将目标文件添加进去,它可将若干单独的文件归并到一个大的文件中。ar crv libfoo.a bill.o fred.o
之后我们要用ranlib
命令为函数库生成一个内容表。
然后我们将库文件和之前生成的program.o文件链接起来,执行成功
也可以用-l
指定函数库,并用-L
指定非标准位置。
我们可以用nm
Lorsque vous appelez gcc, vous pouvez utiliser l'indicateur -I
pour inclure les fichiers d'en-tête enregistrés dans des sous-répertoires ou d'autres emplacements non standard, tels que gcc -I/usr/openwin/include fred. c
/lib
et /usr/lib
. Par défaut, l'éditeur de liens GCC recherche uniquement dans la bibliothèque de langage C standard, ce qui constitue un problème historique. Nous devons conformer le nom du fichier de bibliothèque à une convention spécifique et le spécifier sur la ligne de commande. 🎜🎜🎜Les fichiers de bibliothèque commencent toujours par lib, puis indiquent de quelle bibliothèque il s'agit. La dernière partie .a représente la bibliothèque de fonctions statiques, et .so représente la bibliothèque de fonctions partagée (c'est-à-dire la bibliothèque de liens dynamiques DLL sous Windows). 🎜🎜🎜Tels que gcc -o fred fred.c /usr/lib/libm.a
ou gcc -o fred fred.c -lm
L'indicateur -L
augmente le chemin de recherche de bibliothèque pour l'éditeur de liens, tel que gcc -o x11fred -L /usr/openwin/lib x11fred.c -1X11
🎜🎜🎜2.1 Bibliothèque statique🎜
🎜La bibliothèque statique se termine par .a, également appelé fichier d'archive lors de la génération d'un programme exécutable, le fichier de bibliothèque statique est lié et le fichier exécutable généré est plus volumineux. . Peut être exécuté sans fichiers de bibliothèque statiques. 🎜🎜🎜2.1.1 Méthode de génération🎜
🎜Créez d'abord deux fichiers sources fred.c et bill.c🎜🎜

gcc -c
pour compiler et générer deux Fichier cible🎜🎜


ar crv libfoo.a bill.o fred.o
Ensuite, nous devons utiliser la commande ranlib
pour générer une table de contenu pour la bibliothèque de fonctions. 🎜🎜

-l
pour spécifier la bibliothèque de fonctions et -L
pour spécifier le non- emplacement standard. 🎜🎜nm
pour vérifier quelles fonctions sont incluses dans le fichier cible, la bibliothèque de fonctions ou le fichier exécutable, qui peuvent être utilisés pour l'analyse du désassemblage. Lorsqu'un programme est créé, il ne contient que les fonctions dont il a réellement besoin dans la bibliothèque de fonctions. Bien qu'il existe des déclarations de toutes les fonctions dans le fichier d'en-tête, l'éditeur de liens ne les liera pas toutes. 🎜Comparaison des bibliothèques statiques entre Linux et Windows
2.2 Bibliothèque partagée
Lorsque de nombreuses applications s'exécutent en même temps et qu'elles utilisent toutes des fonctions de la même bibliothèque de fonctions, la mémoire Il y aura de nombreuses copies de la même fonction, ce qui est un gaspillage de mémoire et de stockage externe ! ! Lorsqu'un programme utilise une bibliothèque de fonctions, il ne contient plus de code de fonction lors de la liaison, mais fait référence à du code partagé accessible au moment de l'exécution. Lorsque le programme compilé est chargé en mémoire pour exécution, la référence de fonction est analysée et une paire de The. la bibliothèque partagée est appelée et, si nécessaire, la bibliothèque partagée est chargée en mémoire. Autrement dit, le système ne peut conserver qu'une seule copie de la bibliothèque partagée en mémoire pour de nombreuses applications à appeler, ou il ne peut conserver qu'une seule copie dans la mémoire externe. De plus, les bibliothèques partagées peuvent être mises à jour indépendamment des applications qui en dépendent, et ces applications n'ont pas besoin d'être recompilées.
Dans les systèmes Linux, le programme (chargeur dynamique) responsable du chargement des bibliothèques partagées et des fonctions d'analyse référencées par les programmes clients est ld.so
2.2.1 Méthode de génération
Utilisez le fichier intermédiaire bill.o fred.o génère la bibliothèque partagée libfoo.so gcc -shared -fpic -o libfoo.so bill.o fred.o
gcc -shared -fpic -o libfoo.so bill.o fred.o
生成了共享库后,要置于标准搜索目录下。搜索共享库的额外位置可以在文件/etc/ld.so.conf
中配置,修改这个文件后执行命令ldconfig
来处理。/etc/ld.so.conf
的内容为include /etc/ld.so.conf.d/*.conf
,在此目录下建立自己的动态链接库路径配置文件mylib.conf
然后指定搜索路径
链接生成可执行文件gcc -o main program.o -lfoo -L.
ldd工具可用来分析可执行文件运行所需要的共享库
也可以在编译目标代码时指定.so库的搜索路径,通过gcc 的参数-Wl,-rpath
指定,如gcc main.cpp -lfoo -L. -Wl,-rpath=.
/etc/ld.so.conf
. Après avoir modifié ce fichier, exécutez la commande ldconfig
pour le traiter. Le contenu de /etc/ld.so.conf
est include /etc/ld.so.conf.d/*.conf
, créez votre propre dynamique dans ce répertoire Fichier de configuration du chemin de la bibliothèque de liens mylib.conf
gcc -o programme principal.o -lfoo -L.
🎜🎜-Wl,-rpath
, tel que gcc main.cpp -lfoo - L. -Wl,-rpath=.
-Wl, signifie que les paramètres suivants seront transmis au programme de lien ld (car gcc appellera automatiquement ld lors de la spécification de plusieurs recherches de bibliothèques dynamiques). chemins, utilisez des deux-points entre les chemins. 🎜🎜🎜🎜🎜Recommandations associées : "🎜Tutoriel vidéo 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!

Outils d'IA chauds

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.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

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)

Les principales différences entre Centos et Ubuntu sont: l'origine (Centos provient de Red Hat, pour les entreprises; Ubuntu provient de Debian, pour les particuliers), la gestion des packages (Centos utilise Yum, se concentrant sur la stabilité; Ubuntu utilise APT, pour une fréquence de mise à jour élevée), le cycle de support (CentOS fournit 10 ans de soutien, Ubuntu fournit un large soutien de LT tutoriels et documents), utilisations (Centos est biaisé vers les serveurs, Ubuntu convient aux serveurs et aux ordinateurs de bureau), d'autres différences incluent la simplicité de l'installation (Centos est mince)

CentOS a été interrompu, les alternatives comprennent: 1. Rocky Linux (meilleure compatibilité); 2. Almalinux (compatible avec CentOS); 3. Serveur Ubuntu (configuration requise); 4. Red Hat Enterprise Linux (version commerciale, licence payante); 5. Oracle Linux (compatible avec Centos et Rhel). Lors de la migration, les considérations sont: la compatibilité, la disponibilité, le soutien, le coût et le soutien communautaire.

Étapes d'installation de CentOS: Téléchargez l'image ISO et Burn Bootable Media; démarrer et sélectionner la source d'installation; sélectionnez la langue et la disposition du clavier; configurer le réseau; partitionner le disque dur; définir l'horloge système; créer l'utilisateur racine; sélectionnez le progiciel; démarrer l'installation; Redémarrez et démarrez à partir du disque dur une fois l'installation terminée.

Comment utiliser Docker Desktop? Docker Desktop est un outil pour exécuter des conteneurs Docker sur les machines locales. Les étapes à utiliser incluent: 1. Installer Docker Desktop; 2. Démarrer Docker Desktop; 3. Créer une image Docker (à l'aide de DockerFile); 4. Build Docker Image (en utilisant Docker Build); 5. Exécuter Docker Container (à l'aide de Docker Run).

Docker utilise les fonctionnalités du noyau Linux pour fournir un environnement de fonctionnement d'application efficace et isolé. Son principe de travail est le suivant: 1. Le miroir est utilisé comme modèle en lecture seule, qui contient tout ce dont vous avez besoin pour exécuter l'application; 2. Le Système de fichiers Union (UnionFS) empile plusieurs systèmes de fichiers, ne stockant que les différences, l'économie d'espace et l'accélération; 3. Le démon gère les miroirs et les conteneurs, et le client les utilise pour l'interaction; 4. Les espaces de noms et les CGROUP implémentent l'isolement des conteneurs et les limitations de ressources; 5. Modes de réseau multiples prennent en charge l'interconnexion du conteneur. Ce n'est qu'en comprenant ces concepts principaux que vous pouvez mieux utiliser Docker.

Méthode de visualisation du processus docker: 1. Commande Docker CLI: Docker PS; 2. Commande CLI Systemd: Docker d'état SystemCTL; 3. Docker Compose CLI Commande: Docker-Compose PS; 4. Process Explorer (Windows); 5. / Répertoire proc (Linux).

Vs Code Système Exigences: Système d'exploitation: Windows 10 et supérieur, MacOS 10.12 et supérieur, processeur de distribution Linux: minimum 1,6 GHz, recommandé 2,0 GHz et au-dessus de la mémoire: minimum 512 Mo, recommandée 4 Go et plus d'espace de stockage: Minimum 250 Mo, recommandée 1 Go et plus d'autres exigences: connexion du réseau stable, xorg / wayland (Linux) recommandé et recommandée et plus

Dépannage des étapes pour la construction d'image Docker échouée: cochez la syntaxe Dockerfile et la version de dépendance. Vérifiez si le contexte de construction contient le code source et les dépendances requis. Affichez le journal de construction pour les détails d'erreur. Utilisez l'option - cibler pour créer une phase hiérarchique pour identifier les points de défaillance. Assurez-vous d'utiliser la dernière version de Docker Engine. Créez l'image avec --t [Image-Name]: Debug Mode pour déboguer le problème. Vérifiez l'espace disque et assurez-vous qu'il est suffisant. Désactivez SELINUX pour éviter les interférences avec le processus de construction. Demandez de l'aide aux plateformes communautaires, fournissez Dockerfiles et créez des descriptions de journaux pour des suggestions plus spécifiques.
