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

Windows Forms Discussion :

Tableau string à une dimension


Sujet :

Windows Forms

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé

    Homme Profil pro
    kiné passionné de dev
    Inscrit en
    Mars 2006
    Messages
    1 570
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : kiné passionné de dev

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 570
    Billets dans le blog
    1
    Par défaut Tableau string à une dimension
    Bonjour,
    je bloque sur un truc qui doit etre tout bete, mais impossible de trouver la solution...

    Voilà, j'utilise un tableau string que je voudrais remplir mais je n'y arrive aps.

    mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Dim Listfile() As String
    dim i as integer
    for i = 0 to version.count -1
    Listfile(i) = version(1) 'erreur ICI, il me dit references null
    i += 1
    Next
    Bon, là c'est juste pour l'exemple, car version est un string, alors, mettre un string dans un autre y a pas trop d'interet.

  2. #2
    Membre chevronné
    Inscrit en
    Juin 2007
    Messages
    459
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 459
    Par défaut
    Il faut initialiser Listfile.
    Par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Dim version(10) As String
    Dim Listfile(version.Length) As String

  3. #3
    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
    à savoir qu'il est possible de le déclarer sans limite puis d'utiliser redim pour lui donner sa dimension
    redim preserve redimensionne le tableau en conservant les valeurs qui sont déjà dedans
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  4. #4
    Membre éprouvé

    Homme Profil pro
    kiné passionné de dev
    Inscrit en
    Mars 2006
    Messages
    1 570
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : kiné passionné de dev

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 570
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par BCmDev Voir le message
    Il faut initialiser Listfile.
    Par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Dim version(10) As String
    Dim Listfile(version.Length) As String
    Non, ce n'est pas ce que je veux, car là, tu donnes à l'instanciation la taille du tableau
    Citation Envoyé par sperot51 Voir le message
    à savoir qu'il est possible de le déclarer sans limite puis d'utiliser redim pour lui donner sa dimension
    redim preserve redimensionne le tableau en conservant les valeurs qui sont déjà dedans
    En effet, c'est ce que j'ai utilisé, ça marche à merveille:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Dim Listfile() As String
    dim i as integer
    for i = 0 to version.count -1
    redim preserve listfile(i)
    Listfile(i) = version(1) 'erreur ICI, il me dit references null
    i += 1
    Next

  5. #5
    Membre chevronné
    Inscrit en
    Juin 2007
    Messages
    459
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 459
    Par défaut
    D'après ton exemple, tu connais la taille finale de ton tableau avant l'instanciation. Faire un redim preserve à chaque tour de boucle est un énorme gâchis en termes de performances.

  6. #6
    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
    Citation Envoyé par BCmDev Voir le message
    D'après ton exemple, tu connais la taille finale de ton tableau avant l'instanciation. Faire un redim preserve à chaque tour de boucle est un énorme gâchis en termes de performances.
    +1

    redim preserve indique en général qu'on ne connait pas les collections
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  7. #7
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    Citation Envoyé par BCmDev
    D'après ton exemple, tu connais la taille finale de ton tableau avant l'instanciation. Faire un redim preserve à chaque tour de boucle est un énorme gâchis en termes de performances.
    Et puis une liste dynamique genre ArrayList ou List<T> serait plus adaptée...
    Personnellement je n'utilise jamais de tableaux si je peux m'en passer. Si une méthode prend un tableau en paramètre, on peut toujours convertir la liste en tableau au dernier moment (avec la méthode CopyTo)

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

Discussions similaires

  1. [ezPDF] Scinder un tableau ayant une dimension connue (en cm par exemple)
    Par biquet dans le forum Bibliothèques et frameworks
    Réponses: 0
    Dernier message: 12/05/2015, 10h28
  2. insérer un tableau d'une dimension dans un tableau à deux dimensions
    Par johnny3 dans le forum Collection et Stream
    Réponses: 5
    Dernier message: 03/03/2008, 19h04
  3. Réponses: 1
    Dernier message: 09/03/2007, 17h26
  4. Un string dans un tableau de deux dimensions...
    Par FinalSpirit dans le forum C++
    Réponses: 5
    Dernier message: 15/01/2006, 14h29
  5. Réponses: 1
    Dernier message: 30/09/2005, 19h17

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