Partager via


true, opérateur (Référence C#)

Mise à jour : Juillet 2008

Retourne la valeur booltrue pour indiquer qu'un opérande est true ; sinon, retourne la valeur false.

Avant C# 2.0, les opérateurs true et false étaient utilisés pour créer des types valeur nullables compatibles avec des types tels que SqlBool. Le langage offre désormais une prise en charge intégrée des types valeur nullables qu'il est préférable d'exploiter dès que possible pour ne pas surcharger les opérateurs true et false operators. Pour plus d'informations, consultez Types nullables (Guide de programmation C#).

Avec les valeurs booléennes nullables, l'expression a != b n'équivaut pas nécessairement à !(a == b) puisque que l'une des valeurs ou les deux peuvent être null. Vous devez surcharger à la fois les opérateurs true et false séparément pour identifier comme il se doit les valeurs null dans l'expression. L'exemple suivant montre comment surcharger et utiliser les opérateurs true et false.

// For example purposes only. Use the built-in nullable bool 
// type (bool?) whenever possible.
public struct DBBool
{
    // The three possible DBBool values.
    public static readonly DBBool Null = new DBBool(0);
    public static readonly DBBool False = new DBBool(-1);
    public static readonly DBBool True = new DBBool(1);
    // Private field that stores –1, 0, 1 for False, Null, True.
    sbyte value;
    // Private instance constructor. The value parameter must be –1, 0, or 1.
    DBBool(int value)
    {
        this.value = (sbyte)value;
    }
    // Properties to examine the value of a DBBool. Return true if this
    // DBBool has the given value, false otherwise.
    public bool IsNull { get { return value == 0; } }
    public bool IsFalse { get { return value < 0; } }
    public bool IsTrue { get { return value > 0; } }
    // Implicit conversion from bool to DBBool. Maps true to DBBool.True and
    // false to DBBool.False.
    public static implicit operator DBBool(bool x)
    {
        return x ? True : False;
    }
    // Explicit conversion from DBBool to bool. Throws an exception if the
    // given DBBool is Null; otherwise returns true or false.
    public static explicit operator bool(DBBool x)
    {
        if (x.value == 0) throw new InvalidOperationException();
        return x.value > 0;
    }
    // Equality operator. Returns Null if either operand is Null; otherwise
    // returns True or False.
    public static DBBool operator ==(DBBool x, DBBool y)
    {
        if (x.value == 0 || y.value == 0) return Null;
        return x.value == y.value ? True : False;
    }
    // Inequality operator. Returns Null if either operand is Null; otherwise
    // returns True or False.
    public static DBBool operator !=(DBBool x, DBBool y)
    {
        if (x.value == 0 || y.value == 0) return Null;
        return x.value != y.value ? True : False;
    }
    // Logical negation operator. Returns True if the operand is False, Null
    // if the operand is Null, or False if the operand is True.
    public static DBBool operator !(DBBool x)
    {
        return new DBBool(-x.value);
    }
    // Logical AND operator. Returns False if either operand is False,
    // Null if either operand is Null, otherwise True.
    public static DBBool operator &(DBBool x, DBBool y)
    {
        return new DBBool(x.value < y.value ? x.value : y.value);
    }
    // Logical OR operator. Returns True if either operand is True, 
    // Null if either operand is Null, otherwise False.
    public static DBBool operator |(DBBool x, DBBool y)
    {
        return new DBBool(x.value > y.value ? x.value : y.value);
    }
    // Definitely true operator. Returns true if the operand is True, false
    // otherwise.
    public static bool operator true(DBBool x)
    {
        return x.value > 0;
    }
    // Definitely false operator. Returns true if the operand is False, false
    // otherwise.
    public static bool operator false(DBBool x)
    {
        return x.value < 0;
    }
    public override bool Equals(object obj)
    {
        if (!(obj is DBBool)) return false;
        return value == ((DBBool)obj).value;
    }
    public override int GetHashCode()
    {
        return value;
    }
    public override string ToString()
    {
        if (value > 0) return "DBBool.True";
        if (value < 0) return "DBBool.False";
        return "DBBool.Null";
    }
}

Vous pouvez utiliser un type qui surcharge les opérateurs true et false pour l'expression de contrôle dans les instructions if, do, while et for, ainsi que dans les expressions conditionnelles.

Si un type définit l'opérateur true, il doit aussi définir l'opérateur false.

Un type ne peut pas surcharger directement les opérateurs logiques conditionnels (&& et ||), mais il est possible d'obtenir un résultat équivalent en surchargeant les opérateurs logiques réguliers et les opérateurs true et false.

Spécifications du langage C#

Pour plus d'informations, consultez les sections suivantes dans Spécifications du langage C#.

  • 7.6 Opérateurs unaires

  • 7.11.2 Opérateurs logiques conditionnels définis par l'utilisateur

  • 7.19 Expressions booléennes

Voir aussi

Concepts

Guide de programmation C#

Référence

Mots clés C#

Opérateurs C#

false (Référence C#)

Autres ressources

Référence C#

Historique des modifications

Date

Historique

Raison

Juillet 2008

Ajout d'informations sur la surcharge des opérateurs true et false.

Améliorations apportées aux informations.