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

ASP.NET Discussion :

Comment faire pour libérer la memoire d'un datatable


Sujet :

ASP.NET

  1. #1
    Membre éclairé
    Inscrit en
    Mars 2006
    Messages
    274
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 274
    Par défaut Comment faire pour libérer la memoire d'un datatable
    Comment faire pour libérer la memoire allouée pour datatable. Voici mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
                OleDbConnection cnx = new OleDbConnection(ConnectionString);
                OleDbCommand cmd = new OleDbCommand(sqlquery, cnx);
                DataSet ds = new DataSet();
                cnx.Open();
                OleDbDataAdapter adap = new OleDbDataAdapter(cmd);
                adap.Fill(ds);?
                DataTable table = ds.Tables[0];
                cnx.Close();
    je remarque que le processus Webdevwebserver.exe consomme plus de memoire chaque fois que j'execute une requete. comment faire pour que apes avoir utlisé la datatable je vide la mémoire.

  2. #2
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Par défaut
    Le DataTable sera détruit dès qu'il sera hors de portée (qu'il n'y aura plus aucune référence qui pointe dessus).
    Tu n'as pas à te préoccuper de sa destruction. Ton problème doit sûrement venir d'ailleurs.
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

  3. #3
    Membre éclairé
    Inscrit en
    Mars 2006
    Messages
    274
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 274
    Par défaut
    Ce bout de code est contenu dans une méthode, le datatable est donc une variable locale. normalement elle est detruite lors de la sortie de la méthode qu'elle l'utilise. mais ce qui n'est pas normale c'est que apres la sortie de la méthode la mémoire du processus Webdevwebserver.exe rete la meme! comment faire pour remedier a ce probleme.(la requete selecte retourne un résultat de 20000 ligne)

  4. #4
    Rédacteur
    Avatar de lutecefalco
    Profil pro
    zadzdzddzdzd
    Inscrit en
    Juillet 2005
    Messages
    5 052
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : zadzdzddzdzd

    Informations forums :
    Inscription : Juillet 2005
    Messages : 5 052
    Par défaut
    Citation Envoyé par WELCOMSMAIL Voir le message
    Ce bout de code est contenu dans une méthode, le datatable est donc une variable locale. normalement elle est detruite lors de la sortie de la méthode qu'elle l'utilise. mais ce qui n'est pas normale c'est que apres la sortie de la méthode la mémoire du processus Webdevwebserver.exe rete la meme! comment faire pour remedier a ce probleme.(la requete selecte retourne un résultat de 20000 ligne)
    Le garbage collector ne fonctionne pas comme ça d'après ce que j'ai pu lire.
    En fait, il vide de la mémoire quand la mémoire atteind un certain point.
    Donc tant que le GC n'aura pas estimé qu'il est tant de vidé de la mémoire, il ne le fera pas

  5. #5
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Par défaut
    Citation Envoyé par lutecefalco Voir le message
    Le garbage collector ne fonctionne pas comme ça d'après ce que j'ai pu lire.
    En fait, il vide de la mémoire quand la mémoire atteind un certain point.
    Donc tant que le GC n'aura pas estimé qu'il est tant de vidé de la mémoire, il ne le fera pas
    Exact, c'est également là où je voulais en venir. Si le GC pense qu'il n'a pas besoin de nettoyer la mémoire, il n'y a pas lieu de vouloir le faire absolument.
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

Discussions similaires

  1. comment faire pour qu'une application soit toujours visible ?
    Par goldbar dans le forum Langages de programmation
    Réponses: 2
    Dernier message: 28/03/2004, 14h35
  2. Réponses: 7
    Dernier message: 13/12/2003, 14h09
  3. comment faire pour developper des prog en win32
    Par rhodan51 dans le forum Autres éditeurs
    Réponses: 11
    Dernier message: 09/11/2003, 19h39
  4. Comment faire pour mettre l'ecran en veille ?
    Par March' dans le forum MFC
    Réponses: 6
    Dernier message: 29/08/2002, 14h25
  5. Comment faire pour créer un bitmap
    Par GliGli dans le forum C++Builder
    Réponses: 2
    Dernier message: 24/04/2002, 15h41

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