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

VB.NET Discussion :

Affecter un résultat null (Nothing)


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Avatar de Kropernic
    Homme Profil pro
    Analyste / Programmeur / DBA
    Inscrit en
    Juillet 2006
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyste / Programmeur / DBA
    Secteur : Distribution

    Informations forums :
    Inscription : Juillet 2006
    Messages : 3 932
    Par défaut Affecter un résultat null (Nothing)
    Salut un tous !

    Juste une mini question qui, je crois, passera vite en résolu.

    Alors c'est très simple. J'ai une fonction donc voici la définition :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Public Function X(ByVal unString as String) As String()
    Cette fonction renvoie donc un résultat de type string ou Nothing si aucun résultat n'a pu être produit par la fonction.

    Du coup, quelque chose comme ce qui suit me semblait tout à fait valide :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    Dim str As String() = X(leParamQuiVaBien)
    If not str Is Nothing Then
        'traitement...
    End If
    Mais mon code plante sur l'affectation du résultat de la fonction X dans str lorsque le résultat est Nothing.

    Ma question est : Pourquoi ?

    Si je peux écrire explicitement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim str As String() = Nothing
    , pourquoi ne puis-je pas faire cela via une fonction ?

    Merci d'avance.

    Griftou.

  2. #2
    Membre très actif
    Profil pro
    Inscrit en
    Août 2005
    Messages
    483
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 483
    Par défaut
    Salut

    Pour verifier qu'une chaine de caractère est vide ou null j'utilise ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If string.isNullOrEmpty(MaChaine) then
    Je sais pas si cela que tu recherches

    Et au lieux de renvoyer "nothing" en résultat d'une fonction dont tu sais qu'elle manipule des chaines de caractère, pourquoi ne pas renvoyer une chaine vide?

    ++

  3. #3
    Membre expérimenté
    Avatar de Kropernic
    Homme Profil pro
    Analyste / Programmeur / DBA
    Inscrit en
    Juillet 2006
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyste / Programmeur / DBA
    Secteur : Distribution

    Informations forums :
    Inscription : Juillet 2006
    Messages : 3 932
    Par défaut
    Absolument pas ^^.

  4. #4
    Membre confirmé
    Homme Profil pro
    Développeur .NET et Java (Android)
    Inscrit en
    Mars 2007
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET et Java (Android)
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Mars 2007
    Messages : 21
    Par défaut
    Salut,

    Ta fonction semble retourner un tableau de String alors que tu écris que tu attends une valeur String? Il ne serait pas là ton problème?
    Mais il faudrait en savoir un peu plus sur ce qu’il se passe dans ta fonction.

  5. #5
    Membre expérimenté
    Avatar de Kropernic
    Homme Profil pro
    Analyste / Programmeur / DBA
    Inscrit en
    Juillet 2006
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyste / Programmeur / DBA
    Secteur : Distribution

    Informations forums :
    Inscription : Juillet 2006
    Messages : 3 932
    Par défaut
    Hello,

    La fonction retourne bien un tableau de string et la variable dans laquelle je tente d'affecter le résultat est bien un tableau de string également.

    Il plante vraiment sur l'affectation avec le message "habituel" qui est "Object reference not set to an instance of an object".

    Je ne peux pas utiliser le résultat de la fonction lorsque celui-ci est nothing. Je trouve cela assez gênant...

    Et à vrai dire, je me dois d'être complet... La fonction ne retourne pas vraiment un tableau de string. Elle retourne une chaine avec séparateur (ici ";") que je split pour mettre dans la variable.

    Cela donne donc

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function X(ByBal unString As String) as String
     
    Dim str As String() = X(leParamQuiVaBien).Split(CChar(";"))
    Et du coup, en l'écrivant, je me rend compte que c'est parfaitement normal et que je ne peux pas faire de Split sur rien du tout...

    Méa culpa !!!!

    Note aux admins :
    Vous pouvez supprimer ce topic inutile qui risque d'induires des débutants en erreur...

  6. #6
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Février 2003
    Messages
    2 193
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2003
    Messages : 2 193
    Par défaut
    Petit coquin qui enlève justement l'endroit du bug

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

Discussions similaires

  1. [FileWriter] insertion des résultats null dans le fichier plat
    Par Pakkaï dans le forum Entrée/Sortie
    Réponses: 5
    Dernier message: 28/08/2006, 11h06
  2. affecter le résultat de chaque colonne à une variable
    Par zut94 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 21/11/2005, 17h35
  3. affecter le résultat d'une requête à une variable
    Par zut94 dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 06/10/2005, 17h21
  4. Affectation du résultat d'une ps sans paramètre de sortie
    Par PERRIN38 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 22/08/2005, 15h43
  5. Affecter la valeur NULL à une cellule d'une table
    Par jacma dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 06/05/2005, 14h43

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