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 :

Problème de load d'assembly


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de bilb0t
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    378
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2003
    Messages : 378
    Par défaut Problème de load d'assembly
    Bonjour,

    J'ai une webapplication project.

    En dessous, j'ai une architecture avec factory. (gestion de "module " et non de pluggin)

    Bref, j'ai tout un paquet de dll ds mon rep bin. Et quand je dois loader une classe par le factory, je boucle sur tout les assemblies du current AppDomain et quand je la trouve, j'instancie l'object.

    Le problème, c'est que toutes les dll de bin ne sont pas toujours loader ds le current appdomain...

    Qu'à cela ne tienne, me dis-je.... et zou je fais un assembly.LoadFile(...) de toutes les dll de bin comme ça je suis sur que tout est dedans...
    Et je me retrouve avec plusieurs instances de mes assembly ds le current appdomain avec tout les problèmes qui s'ensuive ( des class semblables mais différentes, des doublons, des singletons qui foirent, ...)

    Je me suis donc dit: "Je vais mettre mes dll de modules ds un autre repertoire et les loader au début de l'applic)...

    Mais là, je ne sais plus parcourir mes assemblies car j'ai l'exception: System.Reflection.ReflectionTypeLoadException qui peut subvenir quand on utilise Assembly.LoadFile d'après la doc.

    Bref je sais plus trop quoi faire...

    Quelqu'un a une idée ?

    Merci

  2. #2
    Rédacteur

    Inscrit en
    Juin 2004
    Messages
    744
    Détails du profil
    Informations personnelles :
    Âge : 44

    Informations forums :
    Inscription : Juin 2004
    Messages : 744
    Par défaut
    Tu ne peux pas tester sir la dll est déjà dans ton appDomain avant de faire un loadFromFile ?
    Envie de contribuer à la rubrique SharePoint ? Contactez moi par MP !

    SharePoint : http://sharepoint.developpez.com
    Mon site : http://lefortludovic.developpez.com
    Mon blog : http://www.consultpoint.net/blog

  3. #3
    Membre éclairé Avatar de bilb0t
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    378
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2003
    Messages : 378
    Par défaut
    c'est ce que j'ai fait à un moment, mais...


    - si je laisse mes dll ds bin: quelquechose(?) à un moment reload les dll qui n'étaient pas préloader et je me retrouve avec des assemblies en double ds mon current appdomain.

    - si je mets mes dll ds /truc: J'ai l'exception System.Reflection.ReflectionTypeLoadException et je ne peux pas parcourir mes assembliez et donc je ne peux pas instancier mes types...

  4. #4
    Membre éclairé Avatar de bilb0t
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    378
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2003
    Messages : 378
    Par défaut
    bon, la bonne technique, c'est vbien le rep à part...


    Ce qu'il faut, c'est dire au current Appdomain ou il peut retrouver mes assemblies:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AppDomain.CurrentDomain.AppendPrivatePath("truc");
    et ça roule !!!

    WOURRAYYY

  5. #5
    Membre éclairé Avatar de bilb0t
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    378
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2003
    Messages : 378
    Par défaut
    Petite remarque...

    La méthode AppendPrivatePath est flaguée à deprecated.

    Il semble qu'il faut utiliser: AppDomain.setupxxx.PrivatePath qui n'est plus un tableau mais un string...

    J'imagine qu'il faut séparer les path par des ;

    Mais de toute façon ça ne fonctionne pas...

  6. #6
    Expert confirmé
    Avatar de smyley
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    6 270
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 6 270
    Par défaut
    à l'origine dans le design de .NET ils voulaient que tous les chemins soit rajoutés avant, la création du AppDomain et donc l'utilisation de AppendPrivateBinPath est une faille, d'où le depreacated cependant je trouve ça totallement absurde car si on ne le fait pas pour les plugins on se retrouve à être obligé de construire quelque chose de compliqué pour contourner celà et finallament, est-ce bien nécéssaire de se forcer à faire dans le compliqué ?

Discussions similaires

  1. Probléme avec load data infile
    Par Moez.B dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 31/08/2006, 10h01
  2. [MySQL] Problème avec LOAD DATA INFILE
    Par Pgs dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 17/07/2006, 15h33
  3. problème avec load data local
    Par afrikha dans le forum Débuter
    Réponses: 2
    Dernier message: 28/10/2005, 18h36
  4. [FLASH MX2004] Problème de loading
    Par Korskarn dans le forum Flash
    Réponses: 3
    Dernier message: 19/08/2005, 08h12
  5. Problème avec LOAD DATA INFILE
    Par ka0z dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 04/06/2004, 14h59

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