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

Dotnet Discussion :

[Vb.net]_Prob. If Then et IIf ?


Sujet :

Dotnet

  1. #1
    Membre actif

    Profil pro
    Inscrit en
    Juin 2002
    Messages
    291
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 291
    Points : 270
    Points
    270
    Par défaut [Vb.net]_Prob. If Then et IIf ?
    Bonjour,

    Quelles différences y a-t-il entre ces deux expressions? (Mise à part qu'il n'y a que la première qui fonctionne )
    Code VB.Net : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
                If objDataReader.IsDBNull(14) Then
                    _IDTblMarque = "-1"
                Else
                    _IDTblMarque = objDataReader.GetInt32(14)
                End If
    Code VB.Net : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
                _IDTblMarque = IIf(objDataReader.IsDBNull(14), "-1", objDataReader.GetInt32(14))


    objDataReader.IsDBNull(14) ne contient aucune valeur.
    La première expression fonctionne par contre sur la deuxième j'ai une erreur de cast...
    Tout ceci se trouve dans une classe, et voici comment est déclaré _IDTblMarque
    Code VB.Net : Sélectionner tout - Visualiser dans une fenêtre à part
    Private _IDTblMarque As Int32
    Code VB.Net : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
     Public Property IDTblMarque() As Int32
            Get
                Return _IDTblMarque
            End Get
            Set(ByVal value As Int32)
                _IDTblMarque = value
            End Set
        End Property

    Merci du renseignement.

    Gwendal

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Juillet 2005
    Messages : 80
    Points : 83
    Points
    83
    Par défaut
    Bonjour.

    Faut juste ce faire une raison : il ne faut pas tester du null avec un iif.
    Il doit évaluer toute la ligne de code, du coup ça plante.

  3. #3
    Membre habitué
    Profil pro
    Développeur informatique
    Inscrit en
    Juin 2002
    Messages
    264
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juin 2002
    Messages : 264
    Points : 174
    Points
    174
    Par défaut
    ...un peu tard mais ça pourra servir pour d'autres...
    iif( effectue les 2 affectations dans tous les cas)
    depuis VS 2008 il existe if() à la place iif() qui n'effectue que l'affectation necesaire et ne planterait donc pas ici...

    c'est un peu comme la différence entre And et andAlso

Discussions similaires

  1. A ceux qui ont migré de VB6 vers VB.Net
    Par Fox dans le forum VB 6 et antérieur
    Réponses: 81
    Dernier message: 21/05/2008, 14h56
  2. [VB.NET] #IF DEBUG THEN Bug
    Par olbi dans le forum VB.NET
    Réponses: 3
    Dernier message: 26/10/2007, 08h16
  3. utiliser les tag [MFC] [Win32] [.NET] [C++/CLI]
    Par hiko-seijuro dans le forum Visual C++
    Réponses: 8
    Dernier message: 08/06/2005, 15h57
  4. [VB.NET] Difficulté de construction... fonction IIF
    Par Pleymo dans le forum Windows Forms
    Réponses: 4
    Dernier message: 09/02/2005, 21h28
  5. Fichier PDOXUSRS.NET
    Par yannick dans le forum Paradox
    Réponses: 5
    Dernier message: 05/04/2002, 09h45

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