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 :

Multithread - SaveFileDialog - DirectoryNotFoundException


Sujet :

C#

  1. #1
    Membre habitué Avatar de stephane.julien
    Inscrit en
    Septembre 2007
    Messages
    342
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Septembre 2007
    Messages : 342
    Points : 130
    Points
    130
    Par défaut Multithread - SaveFileDialog - DirectoryNotFoundException
    Bonjour,

    j'ai une application GUI multithread. Un de mes thread log périodiquement des données dans un fichier de log qui se situe dans l'arborescence du répertoire de travail de mon appli.

    Dans une de mes fenêtre, j'ai un fonction qui me permet d'enregistrer une image. J'utilise pour cela la boîte de dialogue SaveFileDialog de WindowsForms. Je peux également imprimer ma page et j'utilise la fonction print d'un composant externe.

    Lorsque j'imprime, puis que je choisi un imprimante pdf (-> demande de l'emplacement du fichier, comme SaveFileDialog), ou que j'ouvre ma boîte de dialogue SaveFileDialog, un exception de type DirectoryNotFoundException est levée dans mon thread qui écrit le fichier de log.

    Est-ce que les boîtes de dialoge SaveFileDialog bloque l'accès de l'application au répertoire courant? Comment résoudre mon problème?

    Merci d'avance de votre aide...

  2. #2
    Membre expérimenté
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 103
    Points : 1 561
    Points
    1 561
    Par défaut
    ton thread logger est un thread totalement autonome ?
    il gere lui meme son fichier, utilise pas de composant intégré type winform ou comme le composant EventLogger ?

    l'excepton à lieu au moment où ta boite de dialogue s'affiche ou au moment où le thread de log, traite le fichier de log ?

  3. #3
    Membre habitué Avatar de stephane.julien
    Inscrit en
    Septembre 2007
    Messages
    342
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Septembre 2007
    Messages : 342
    Points : 130
    Points
    130
    Par défaut
    Mon thread de log est complètement indépendant. Voilà ma méthode que mon thread appelle pour écrire dans le fichier de log :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
     
        public override void WriteLog(string _sMessage)
        {
          if (!IsEnabled)
            return;
     
          string[] lines = _sMessage.Split(Environment.NewLine.ToCharArray());
          lock (this)
          {
            StreamWriter l_Writer = new StreamWriter(Url, true);
     
            foreach (string l_sLine in lines)
              l_Writer.Write(ToLogFormat(l_sLine));
            l_Writer.Dispose();
          }
        }
    L'exception est levée lorsque je créé mon StreamWriter. L'URL est un nom de fichier dans mon répertoire de travail...

  4. #4
    Membre éclairé
    Profil pro
    Ingénieur sécurité
    Inscrit en
    Février 2007
    Messages
    574
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur sécurité
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2007
    Messages : 574
    Points : 751
    Points
    751
    Par défaut
    Question stupide : tu es sur du chemin de ton URL? Tu as bien orthographié le nom de fichier?

  5. #5
    Membre habitué Avatar de stephane.julien
    Inscrit en
    Septembre 2007
    Messages
    342
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Septembre 2007
    Messages : 342
    Points : 130
    Points
    130
    Par défaut
    Oui car l'écriture du log fonctionne très bien quand cette fameuse boîte de dialogue est fermée.

  6. #6
    Membre habitué Avatar de stephane.julien
    Inscrit en
    Septembre 2007
    Messages
    342
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Septembre 2007
    Messages : 342
    Points : 130
    Points
    130
    Par défaut
    J'ai toujours le même prolème, personne n'a d'idée?

  7. #7
    Membre habitué Avatar de stephane.julien
    Inscrit en
    Septembre 2007
    Messages
    342
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Septembre 2007
    Messages : 342
    Points : 130
    Points
    130
    Par défaut
    Le problème venait de l'URL de mon fichier de log. Avant, j'utilisais ".\Log\system.log" et j'avais l'exception DirectoryNotFoundException.

    Maintenant, j'utilise Environment.CurrentDirectory+@"\Log\System.log" et ça fonctionne.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Kylix] Multithreads la galère
    Par Oyoboy dans le forum EDI
    Réponses: 16
    Dernier message: 16/07/2004, 12h03
  2. [WinAPI C++] MultiThreading et PostMessage
    Par Gruik dans le forum Windows
    Réponses: 7
    Dernier message: 29/03/2004, 16h58
  3. [WinAPI C++] MultiThreading?
    Par Gruik dans le forum Windows
    Réponses: 2
    Dernier message: 25/03/2004, 01h08
  4. [Win32]App multithread
    Par billyboy dans le forum Windows
    Réponses: 5
    Dernier message: 25/09/2003, 10h57
  5. Multithreading sous HP Ux 11
    Par pykoon dans le forum Autres éditeurs
    Réponses: 1
    Dernier message: 19/10/2002, 00h36

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