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 :

VS2008/.net/winforms : convertir string[] en List<string> ?


Sujet :

C#

  1. #1
    Membre Expert Avatar de Lorenzo77
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    1 472
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 472
    Par défaut VS2008/.net/winforms : convertir string[] en List<string> ?
    salut,

    est ce qu'il existe une manière de transformer un string[] en List<string> sans utiliser une boucle sur l'intégralité des éléments ?
    ca doit être faisable vu que les 2 sont très proche !?

    j'ai essayé contenu.Cast<List<string>>() mais ca plante :
    Impossible de convertir implicitement le type 'System.Collections.Generic.IEnumerable<System.Collections.Generic.List<string>>' en 'System.Collections.Generic.List<string>'. Une conversion explicite existe (un cast est-il manquant*?)
    une idée ?

    merci

  2. #2
    Membre éclairé Avatar de gdkenny
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    251
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juillet 2005
    Messages : 251
    Par défaut
    Salut.

    ce code marche à partir du framework 3.0:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    string[] t; t.ToList();
    Les méthodes d'extension, c'est bien. CQFD


  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 88
    Par défaut
    tiens c'est cool ca !

    Et c'est vraiment en O(1) comme opération ? Aucun parcours du tableau ?

  4. #4
    Membre éclairé Avatar de gdkenny
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    251
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juillet 2005
    Messages : 251
    Par défaut
    Si, il doit y avoir parcours, vu que ToList() est une méthode d'extension de l'interface IEnumerable<T>.

    Il y a même un p'tit coup d'inférence de type par dessus. Je sais pas ce que ca donne niveau performances, en tout cas c'est bien pratique

  5. #5
    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
    Citation Envoyé par ArianeV Voir le message
    Et c'est vraiment en O(1) comme opération ? Aucun parcours du tableau ?
    Ah mon avis c'est plus un O(n) car il faut après tout copier les valeurs du tableau vers la liste (qui n'est pas un tableau) ou en tout cas dupliquer le tableau. Mais de toute façon vu que c'est au maximum linéaire ça doit pas être très pénalisant.

  6. #6
    Membre expérimenté
    Avatar de StormimOn
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2005
    Messages
    2 593
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Sarthe (Pays de la Loire)

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 593
    Par défaut
    Citation Envoyé par Lorenzo77 Voir le message
    est ce qu'il existe une manière de transformer un string[] en List<string> sans utiliser une boucle sur l'intégralité des éléments ? ca doit être faisable vu que les 2 sont très proche !?
    Non ce n'est pas faisable. Ce n'est pas parce que les notions sont "proches" que les conversions sont pour autant possibles.

    Boucler est inutile dans le cas présent puisque le framework est capable de le faire lui même. La plupart des classes de collections acceptent un IEnumerable via le constructeur ou bien possèdent une méthode AddRange pour ajouter plusieurs éléments.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    string[] tabString = { "chaine1", "chaine2", "chaine3" };
    // Méthode 1
    List<string> listString1 = new List<string>(tabString);
    // Méthode 2
    List<string> listString2 = new List<string>();
    listString2.AddRange(tabString);

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 88
    Par défaut
    Hmmm

    Donc finalement ce n'est pas possible de passer du tableau à la liste sans faire de parcours de tous les éléments (vu que c'est le framework qui le fait)...

    C'est bien dommage...

  8. #8
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut
    le framework le fait mais il doit faire une boucle (ou mieux en optimisé vu que niveau mémoire ca doit se suivre)

    m'enfin ce genre de choses est ultra rapide
    .net pour tout ce qui est non graphique ca turbine !
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  9. #9
    Membre Expert Avatar de Lorenzo77
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    1 472
    Détails du profil
    Informations personnelles :
    Âge : 53
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 472
    Par défaut
    merci a vous

  10. #10
    Membre Expert Avatar de Guulh
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    2 160
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2007
    Messages : 2 160
    Par défaut
    Il me semble avoir vu dans ce forum que le constructeur de List qui prend un IEnumerable en entrée vérifie si le paramètre est une icollection, auquel cas il en extrait la taille, de façon à allouer dès le début une capacité suffisante. Un petit coup de Reflector nous en dirait plus

  11. #11
    Membre éclairé Avatar de gdkenny
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    251
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juillet 2005
    Messages : 251
    Par défaut
    Citation Envoyé par Guulh Voir le message
    Il me semble avoir vu dans ce forum que le constructeur de List qui prend un IEnumerable en entrée vérifie si le paramètre est une icollection, auquel cas il en extrait la taille, de façon à allouer dès le début une capacité suffisante.
    Je comprend pas l'intérêt la: une liste par définition alloue dans le tas des emplacements non consécutifs;c'est dynamique quoi.
    A moins que ce soit plus rapide de (1)allouer l'espace, (2)populer les données, dans ce cas de 'cast'?

  12. #12
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 88
    Par défaut
    Non

    En .NET List est l'équivalent du Vector en C++ : c'est un tableau dynamique.

    En gros, sa taille augmente mais les emplacements sont contigus : l'intérêt c'est que tu ne passes pas ton temps à allouer de l'espace.

    En plus, quand tu accèdes à l'élément numéro 150 de ta liste, il sait directement où il se trouve. si tu étais dans une liste chainée, il devrait parcourir les 149 premiers pour savoir où se trouve le 150ème, ce qui est dramatique au niveau perf

    Ceci étant, tous les éléments ne sont pas contigus je crois. Techniquement, c'est plutot une liste chainée de tableaux. Du coup le temps est quasiment constant, et tu peux le faire grossir à la volée sans que ca ne te coute rien.

  13. #13
    Membre éclairé Avatar de gdkenny
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    251
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juillet 2005
    Messages : 251
    Par défaut
    OK.

    Pourquoi il l'on pas appelé Vector leur liste alors?
    Et sinon, il y a une vraie liste chaînée en .NET?

  14. #14
    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
    LinkedList<T>

  15. #15
    Membre éclairé Avatar de gdkenny
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    251
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juillet 2005
    Messages : 251
    Par défaut
    Merci

  16. #16
    Membre Expert Avatar de Guulh
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    2 160
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2007
    Messages : 2 160
    Par défaut
    Citation Envoyé par ArianeV Voir le message
    Ceci étant, tous les éléments ne sont pas contigus je crois. Techniquement, c'est plutot une liste chainée de tableaux. Du coup le temps est quasiment constant, et tu peux le faire grossir à la volée sans que ca ne te coute rien.
    On ne dirait pas. La msdn dit ( http://msdn.microsoft.com/fr-fr/libr...d1(VS.80).aspx ):
    Si Count est inférieur à Capacity, cette méthode est une opération O(1). Si la capacité doit être augmentée pour intégrer le nouvel élément, cette méthode devient une opération O(n), où n est égal à Count.
    Ce qui laisse croire que si la capacité est insuffisante, on recopie le buffer existant dans un buffer plus grand.

    Et pourquoi ça s'appelle pas vector ? Parce que c'est pas un vecteur, et que la STL n'a pas des conventions de nommage universelles

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

Discussions similaires

  1. convertir une liste en string
    Par tntneo dans le forum Prolog
    Réponses: 2
    Dernier message: 03/04/2010, 02h24
  2. Concaténer une liste de string en un seul string
    Par Msysteme dans le forum Windows Forms
    Réponses: 5
    Dernier message: 27/02/2009, 12h00
  3. [VB.Net] Comment convertir un string en double ?
    Par Aspic dans le forum VB.NET
    Réponses: 2
    Dernier message: 17/10/2006, 19h04
  4. Réponses: 4
    Dernier message: 13/07/2006, 11h23
  5. [VB.net] Join d'un Array list de string?
    Par the_bmo dans le forum VB.NET
    Réponses: 8
    Dernier message: 15/12/2005, 13h53

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