


Solution aux conflits entre symboles de même nom sous Linux
Cet article présente principalement des informations pertinentes sur la solution au problème des symboles en conflit avec le même nom sous Linux. Les amis qui en ont besoin peuvent se référer à
Solution au problème des symboles en conflit avec le. même nom sous Linux
J'ai récemment rencontré le problème ennuyeux suivant au travail :
Il y a trois modules aa, bb et cc sous Linux La situation de base est la suivante :
cc Compilez et connectez-vous pour obtenir cc donc une bibliothèque dynamique, il y a les interfaces suivantes dans cc :
cc_fun { …… do();//调用名为do的cc模块内部函数 …… }
bb compilez et connectez-vous pour obtenir la bibliothèque bb.a static, Il y a les interfaces suivantes dans bb :
bb_fun { …… handle = dlopen(cc.so, RTLD_LAZY);//加载cc.so pccfun = dlsym(handle, “cc_fun”);//获取cc_fun函数指针 (*pccfun)();//调用cc_fun函数,此时应该会调用cc模块中的do()函数 do();//调用名为do的bb模块内部函数(与cc模块中的do()函数同名,实现却不相同) …… }
aa Après compilation, connectez-vous bb.a via l'option de lien -lbb pour obtenir le programme exécutable aa, et appeler la fonction d'interface bb.a bb_fun() :
main { …… bb_fun();//调用bb_fun函数 …… }
Pendant le travail, il a été constaté que aa se comporte anormalement pendant l'exécution. Il y a toujours des fuites de mémoire et des anomalies fonctionnelles. Le problème s'est avéré être centré sur la fonction do() du même nom. Grâce à l'impression des résultats, il a été constaté que les deux appels à la fonction do() dans le programme appelaient tous deux la fonction do() dans le module bb, tandis que la fonction do() dans le module cc n'était jamais appelée, ce qui entraînait un programme anormal. comportement et fuites de mémoire.
Après plusieurs vérifications, j'ai appris que parce que les tables de symboles de chaque bibliothèque du programme Linux seront éventuellement chargées dans la table de symboles globale où se trouve le programme, à ce moment-là, s'il y a un symbole avec le même nom, il ne peut être appelé qu'au premier symbole chargé, c'est-à-dire que les symboles du même nom chargés ultérieurement seront écrasés par les précédents. La fonction do() du module cc est écrasée par la fonction do() du module bb, elle ne peut donc pas être appelée. Fini les bêtises. . .Après avoir essayé de nombreuses méthodes insatisfaisantes, la solution finale est la suivante :
1 Ajoutez -Wl, -Bsymbolic -Wl, au makefile cc --version. -script, l'option de connexion de la version, signifie utiliser le script dans le fichier de version pour spécifier les fonctions qu'il exporte. Le fichier 2.version est implémenté comme suit :VERS{ global: cc_fun; local: *; };
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)

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).

É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.

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.

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).

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.

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.

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
