IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C++ Discussion :

[Visual Studio 2008] Probleme de compilation de DLL avec Late Linking


Sujet :

C++

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Août 2008
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 56
    Points : 44
    Points
    44
    Par défaut [Visual Studio 2008] Probleme de compilation de DLL avec Late Linking
    Bonjour,

    Je suis en train de programmer un serveur generique.
    Ce serveur met a dispositions des DLLs qu'il charge une class permetant les interactions avec les autres DLLs et le network.

    Seulement voila je rencontre un petit souci avec la compilation des DLLs. Ces dernieres ne doivent pas contenir le code du serveur. Mais elles doivent quand meme y faire appelle.

    J'ai donc include les .h contenant le typages des fonctions dans la DLL.

    A la compilation de la DLL VS me dit "unresolved external symbol" ce qui veut dire si je comprends bien qu'il ne trouve pas le corps de la fonction !

    Comment dire a Visual que le Linking doit se faire au chargement de la DLL et pas avant ?

    J'ai fais un petit test sous Linux et cela fonctionne sans souci, il fait bien le linking au moment du chargement du .so !

    Les Pros de VS ont il une idee ?

    Merci d'avance

  2. #2
    screetch
    Invité(e)
    Par défaut
    sous linux les DLL (enfin les SO) peuvent utiliser les symboles du programme qui les charge, ce qui n'est pas le cas sous windows.
    En revanche, sous windows, un executable est quasiment equivalent a une DLL. lorsque tu compiles ton executable sous visual C++, tu peux demander a generer le .lib avec, ce qui te permet de créer une DLL qui utilise l'executable comme DLL.

    Au runtime, l'executable va charger la DLL et cette DLL va se lier a l'executable (qui est deja chargé, donc bingo) et on a ainsi le meme comportement sous windows et linux.
    En revanche, il va peut etre falloir apporter quelques modifs a ton build, et également retravailler ton executable pour exporter tous les symboles dont ta DLL a besoin, ca peut etre un peu fastidueux (il va falloir utiliser __declspec(dllexport) partout dans l'exe)

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Août 2008
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 56
    Points : 44
    Points
    44
    Par défaut
    Ok ...

    Si je comprends bien j'ai juste a rajouter le __declspec(dllexport) devant les methods dans l'exe et faire en sorte que l'exe soit compile avant la Dll avec les dependances ?
    Parceque le linker n'arrive toujours pas a completer la compilation ...

    Sinon visiblement y'a moyen d'eviter les __declspec(dllexport) devant toutes les methods parceque ca risque de faire un code attroce quand je vais le porter sur Linux.

    D'apres la msdn il y a plusieurs facons de declarer les exports :

    • The __declspec(dllexport) keyword in the source code
    • EXPORTS statement in a .def file
    • An /EXPORT specification in a LINK command


    L'autre solution que j'ai trouve en fouillant, c'est d'utiliser les .exp !

    Normalement les .exp permetent de resoudre les problemes d'appelles circulaires. Genre A a besoins d'une method dans B et B a besoins d'une method dans A.

    Tu as entendu parle de cette solution ?

  4. #4
    screetch
    Invité(e)
    Par défaut
    pas vraiment, je trouve perso que le declspec(dllexport) est ce qu'il y a de plus portable et de plus propre car ca permet de selectionner quelles fonctions doivent etre exportées. l'equivalent sous linux est __attribute__((visibility=default)) je crois qui te permet de publier seulement quelques symboles. ca donne quelques macros a ecrire mais ca rend le code plus propre je trouve.
    je crois que les fichier exports ne marchent pas en C++ a cause du mangling pas pas sûr.

  5. #5
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Sinon, plutôt qu'avoir une dépendance circulaire, pourquoi ne pas proposer tes fonctions à la DLL en callback ?
    Par exemple, tu lui files un pointeur d'interface...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Réponses: 8
    Dernier message: 27/07/2012, 14h59
  2. Réponses: 10
    Dernier message: 05/02/2009, 13h22
  3. Utilisation dll - visual studio 2008 - c++
    Par >-[]-Fab-[]-< dans le forum Windows
    Réponses: 9
    Dernier message: 22/05/2008, 15h53
  4. problème compil visual studio 2008
    Par bitrate dans le forum Visual C++
    Réponses: 1
    Dernier message: 28/04/2008, 08h41

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo