Выражения значений по умолчанию — создание значения по умолчанию

Выражение default value создает значение по умолчанию для типа. Выражения default value бывают двух видов: вызов оператора default и литерал default.

Также используется ключевое слово default в качестве метки варианта по умолчанию в инструкции switch.

оператор по умолчанию

Оператор default принимает в качестве аргумента имя типа или параметр типа, как показано в следующем примере:

Console.WriteLine(default(int));  // output: 0
Console.WriteLine(default(object) is null);  // output: True

void DisplayDefaultOf<T>()
{
    var val = default(T);
    Console.WriteLine($"Default value of {typeof(T)} is {(val == null ? "null" : val.ToString())}.");
}

DisplayDefaultOf<int?>();
DisplayDefaultOf<System.Numerics.Complex>();
DisplayDefaultOf<System.Collections.Generic.List<int>>();
// Output:
// Default value of System.Nullable`1[System.Int32] is null.
// Default value of System.Numerics.Complex is (0, 0).
// Default value of System.Collections.Generic.List`1[System.Int32] is null.

Литерал default

Можно использовать default литерал для создания значения по умолчанию типа, когда компилятор может определить тип выражения. Литеральное выражение default создает то же значение, что и выражение default(T), где T является выведенным типом. Литерал default можно использовать в любом из следующих случаев:

Ниже приведен пример применения литерала default.

T[] InitializeArray<T>(int length, T initialValue = default)
{
    if (length < 0)
    {
        throw new ArgumentOutOfRangeException(nameof(length), "Array length must be nonnegative.");
    }

    var array = new T[length];
    for (var i = 0; i < length; i++)
    {
        array[i] = initialValue;
    }
    return array;
}

void Display<T>(T[] values) => Console.WriteLine($"[ {string.Join(", ", values)} ]");

Display(InitializeArray<int>(3));  // output: [ 0, 0, 0 ]
Display(InitializeArray<bool>(4, default));  // output: [ False, False, False, False ]

System.Numerics.Complex fillValue = default;
Display(InitializeArray(3, fillValue));  // output: [ (0, 0), (0, 0), (0, 0) ]

Совет

Используйте правило стиля .NET IDE0034, чтобы задать предпочтительное использование литерала default в вашей базе кода.

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

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

См. также