Оператор true (Справочник по C#)

Обновлен: Июль 2008

Возвращает логическое значение true, чтобы указать на то, что операнд ложный, а в противном случае возвращает false.

В версиях до версии C# 2.0 операторы true и false использовались для создания пользовательских нулевых типов значений, которые были совместимыми с такими типами, как SqlBool. Однако теперь язык предоставляет встроенную поддержку для нулевых типов значений и по возможности следует использовать их вместо перегрузки операторов true и false. Дополнительные сведения см. в разделе Типы, допускающие значения NULL (руководство по программированию на C#).

С нулевыми логическими значениями выражение a != b не обязательно равно !(a == b), поскольку одно или оба значения могут быть нулевыми. Необходимо отдельно перегрузить операторы true и false, чтобы правильно определить нулевые значения в выражении. В следующем примере показана перегрузка и применение операторов true и 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";
    }
}

Тип, перегружающий операторы true и false, может использоваться для выражения управления в операторах if, do, while и for и в условных выражениях.

Если тип определяет оператор true, он должен определить и оператор false.

Тип не может непосредственно перегрузить условные логические операторы (&& и ||), однако такой же результат может быть достигнут путем перегрузки регулярных логических операторов и операторов true и false.

Спецификация языка C#

Дополнительные сведения см. в следующих разделах документа Спецификация языка C#:

  • 7.6 Унарные операторы

  • 7.11.2 Определенные пользователем условные логические операторы

  • 7.19 Логические выражения

См. также

Основные понятия

Руководство по программированию в C#

Ссылки

Ключевые слова C#

Операторы C#

false (Справочник по C#)

Другие ресурсы

Справочник по C#

Журнал изменений

Дата

Журнал изменений

Причина

Июль 2008

Добавлены сведения о перегрузке операторов true и false.

Улучшение информации.