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

WinDev Discussion :

fermeture appli dure longtemps


Sujet :

WinDev

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    425
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 425
    Points : 129
    Points
    129
    Par défaut fermeture appli dure longtemps
    Bonjour,

    Après analyse je constate que mon appli mets 45sec à se fermer complètement dans la mémoire, après fermeture de la fenêtre principale.

    Un des warnings est (j'en ai 5 les mêmes pour différents threads) :

    Le thread '1' est bloqué et n'a pas pu être arrêté normalement, il a été détruit.
    ----- Informations techniques -----
    Projet : ANXe
    Que s'est-il passé ?
    Le thread '1' est bloqué et n'a pas pu être arrêté normalement, il a été détruit.
    Code erreur : 2926
    Niveau : warning (EL_WARNING_EXECUTION)
    Dump de l'erreur du module 'wd170vm.dll' (17.0.247.5).
    Identifiant des informations détaillées (.err) : 2926
    Informations supplémentaires :
    EIT_DATEHEURE : 16/01/2013 19:38:04


    Hors je mets dans le code de fermeture de mon appli, executé par finprogramme("",vrai)

    ThreadArrête(threadPrincipal)
    ThreadArrête("1")
    ThreadArrête("1b")
    ThreadArrête("1c")
    ThreadArrête("2")
    ThreadArrête("3")
    ThreadArrête("4")
    ThreadArrête("5")
    HFerme("*")
    HAnnuleDéclaration(REQ_PM_merken)
    HAnnuleDéclaration(REQ_connector)


    HAnnuleDéclaration(REQ_polarity)

    ---
    Donc comment y remédier ? comment fermer/libérer plus rapidement la mémoire ?

    BAV

  2. #2
    Membre éprouvé Avatar de miripesage
    Homme Profil pro
    gerant
    Inscrit en
    Novembre 2009
    Messages
    725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : gerant
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2009
    Messages : 725
    Points : 1 156
    Points
    1 156
    Par défaut
    bonjour, faire un timeout null

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    //ThreadArrête(threadPrincipal)//pas nécessaire avec FinProgramme()
    ThreadArrête("1",0)
    ThreadArrête("1b",0)
    ThreadArrête("1c",0)
    ThreadArrête("2",0)
    ThreadArrête("3",0)
    ThreadArrête("4",0)
    ThreadArrête("5",0)

  3. #3
    Expert éminent
    Avatar de frenchsting
    Homme Profil pro
    multitâches-multifonctions
    Inscrit en
    Juin 2003
    Messages
    5 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : multitâches-multifonctions
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2003
    Messages : 5 389
    Points : 9 564
    Points
    9 564
    Par défaut
    Regarde également l'ordre de création/dépendance de tes threads/requêtes...

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    425
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 425
    Points : 129
    Points
    129
    Par défaut
    @ frenchsting : que veux-tu dire ? Je ne comprends pas très bien ...
    L'ordre ; lequel commence en premier etc...

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    425
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 425
    Points : 129
    Points
    129
    Par défaut
    le timeout 0 ne change rien

    ...

    et je n'arrive pas à fermer l'api avec api("Kernel32","CloseHandle",ihandle),
    getlasterror = 6 (je suppose access denied)

    Que faire ?
    ....

    Ceux qui ne se ferment pas sont en faite des sniffer de folder :

    iHandle = API("Kernel32","CreateFileA",&strRep,FILE_LIST_DIRECTORY,OUBinaire(FILE_SHARE_READ,FILE_SHARE_WRITE),Null,OPEN_EXISTING,FILE_FLAG_BACKUP_SEMANTICS,Null)
    SI iHandle <> INVALID_HANDLE_VALUE ALORS
    bContinuer = Vrai
    TANTQUE bContinuer
    iPos = 0
    SI API("Kernel32","ReadDirectoryChangesW",iHandle,&bBuffer,1024,Vrai,FILE_NOTIFY_CHANGE_FILE_NAME,&iNull_1,&iNull_2,&iNull_3) <> 0 ALORS
    TANTQUE Vrai
    Transfert(&strFile,&strFileVide,1024)
    Transfert(&struFile,&bBuffer+iPos,Dimension(struFile))
    SELON struFile:Action
    CAS FILE_ACTION_ADDED:
    //Trace("Ajout")
    ...
    TANTQUE Waitsignal<>""
    FIN
    PostMessage(Handle(FEN_main),"lance",0,0)
    ThreadAttendSignal()
    CAS FILE_ACTION_REMOVED:
    //Trace("Delete")
    //Transfert(&strFile,&bBuffer+iPos+Dimension(struFile),struFile:FileNameLength)
    CAS FILE_ACTION_MODIFIED:
    //Trace("Modif")
    //Transfert(&strFile,&bBuffer+iPos+Dimension(struFile),struFile:FileNameLength)
    CAS FILE_ACTION_RENAMED_OLD_NAME:
    //Trace("Ren old")
    //Transfert(&strFile,&bBuffer+iPos+Dimension(struFile),struFile:FileNameLength)
    CAS FILE_ACTION_RENAMED_NEW_NAME:
    //Trace("Ren new")
    //Transfert(&strFile,&bBuffer+iPos+Dimension(struFile),struFile:FileNameLength)
    AUTRE CAS
    //Trace("rien")
    FIN
    //Trace(struFile:FileNameLength)
    //Trace(UnicodeVersAnsi(strFile))

    SI struFile:NextEntryOffset <> 0 ALORS
    iPos += struFile:NextEntryOffset
    SINON
    SORTIR
    FIN

    FIN
    SINON
    Erreur()
    FIN

    // bcontinuer = ouinon("continuer?")
    FIN
    API("Kernel32","CloseHandle",iHandle)
    // api("Kernel32","CloseHandle",ihandle)
    SINON
    Erreur()
    FIN

  6. #6
    Expert éminent
    Avatar de frenchsting
    Homme Profil pro
    multitâches-multifonctions
    Inscrit en
    Juin 2003
    Messages
    5 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : multitâches-multifonctions
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2003
    Messages : 5 389
    Points : 9 564
    Points
    9 564
    Par défaut
    Citation Envoyé par chapeau_melon Voir le message
    @ frenchsting : que veux-tu dire ? Je ne comprends pas très bien ...
    L'ordre ; lequel commence en premier etc...
    Si tu as un thread a qui appelle un thread b, alors arrête le thread b d'abord...

    Ceci -> TANTQUE Vrai, doit poser un problème d'arrêt. Utilise plutôt une variable booléenne globale, qui sera mise à faux lors de la fermeture du programme.

    Tu peux également faire un coup d'analyseur de performances pour tracer l'arrêt.

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    425
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 425
    Points : 129
    Points
    129
    Par défaut
    hmmm...la variable globale, bContinuer=faux, lancé depuis le thread principal, code de fermeture, n'est pas pris en compte ?

    Comment faire ?

    Par contre, quand j'active le // bcontinuer = ouinon("continuer?")
    et que je selectionne 'non' effectivement l'
    API("Kernel32","CloseHandle",iHandle) est effective et le threadtermine("1",0) est = vrai.

  8. #8
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    425
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 425
    Points : 129
    Points
    129
    Par défaut
    Bon pour l'instant je n'ai rien trouvé de mieux que de mettre
    ExeTermine(ExeDonnePID()) à la dernière ligne de fin du programme.
    La mémoire est libéré instantanément et je ne crains riens car tous les fichiers (req/etc...) sont proprement fermés.

    Si jamais vous avez d'autres avis ??

    BAV

Discussions similaires

  1. Réponses: 7
    Dernier message: 17/03/2014, 17h20
  2. [Thread] et destruction par fermeture appli
    Par Droïde Système7 dans le forum Débuter
    Réponses: 8
    Dernier message: 15/12/2008, 20h17
  3. appel service web puis fermeture appli appelante
    Par gerald2545 dans le forum Windows Forms
    Réponses: 5
    Dernier message: 22/08/2007, 13h27
  4. [VBA - Excel] fermeture appli externe
    Par Chewi dans le forum Macros et VBA Excel
    Réponses: 17
    Dernier message: 17/01/2007, 16h49
  5. [vb6]Pb fermeture appli
    Par R@IZER dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 28/02/2006, 17h52

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