?? e ?? = operadores - os operadores de coalescência nula

O operador ?? de coalescência nula retorna o valor de seu operando esquerdo se não nullfor, caso contrário, ele avalia o operando direito e retorna seu resultado. O ?? operador não avalia seu operando direito se o operando esquerdo for avaliado como não-nulo. O operador ??= de atribuição de coalescência nula atribui o valor de seu operando direito ao operando esquerdo somente se o operando esquerdo for avaliado como null. O ??= operador não avalia seu operando direito se o operando esquerdo for avaliado como não-nulo.

List<int>? numbers = null;
int? a = null;

Console.WriteLine((numbers is null)); // expected: true
// if numbers is null, initialize it. Then, add 5 to numbers
(numbers ??= new List<int>()).Add(5);
Console.WriteLine(string.Join(" ", numbers));  // output: 5
Console.WriteLine((numbers is null)); // expected: false        


Console.WriteLine((a is null)); // expected: true
Console.WriteLine((a ?? 3)); // expected: 3 since a is still null 
// if a is null then assign 0 to a and add a to the list
numbers.Add(a ??= 0);
Console.WriteLine((a is null)); // expected: false        
Console.WriteLine(string.Join(" ", numbers));  // output: 5 0
Console.WriteLine(a);  // output: 0	        

O operando esquerdo do ??= operador deve ser uma variável, uma propriedade ou um elemento indexador .

O tipo do operando esquerdo dos operadores e ??= não pode ser um tipo de ?? valor não anulável. Em particular, você pode usar os operadores de coalescência nula com parâmetros de tipo sem restrições:

private static void Display<T>(T a, T backup)
{
    Console.WriteLine(a ?? backup);
}

Os operadores de coalescência nula são associativos à direita. Ou seja, expressões da forma

a ?? b ?? c
d ??= e ??= f

são avaliados como

a ?? (b ?? c)
d ??= (e ??= f)

Exemplos

Os ?? operadores e ??= podem ser úteis nos seguintes cenários:

  • Em expressões com os operadores ?. null-conditional e ?[], você pode usar o ?? operador para fornecer uma expressão alternativa para avaliar caso o resultado da expressão com operações null-conditional seja null:

    double SumNumbers(List<double[]> setsOfNumbers, int indexOfSetToSum)
    {
        return setsOfNumbers?[indexOfSetToSum]?.Sum() ?? double.NaN;
    }
    
    var sum = SumNumbers(null, 0);
    Console.WriteLine(sum);  // output: NaN
    
  • Quando você trabalha com tipos de valor anuláveis e precisa fornecer um valor de um tipo de valor subjacente, use o ?? operador para especificar o valor a ser fornecido no caso de um valor de tipo anulável ser null:

    int? a = null;
    int b = a ?? -1;
    Console.WriteLine(b);  // output: -1
    

    Use o Nullable<T>.GetValueOrDefault() método se o valor a ser usado quando um valor de tipo anulável é null deve ser o valor padrão do tipo de valor subjacente.

  • Você pode usar uma throw expressão como o operando direito do operador para tornar o código de verificação de ?? argumentos mais conciso:

    public string Name
    {
        get => name;
        set => name = value ?? throw new ArgumentNullException(nameof(value), "Name cannot be null");
    }
    

    O exemplo anterior também demonstra como usar membros com corpo de expressão para definir uma propriedade.

  • Você pode usar o ??= operador para substituir o código do formulário

    if (variable is null)
    {
        variable = expression;
    }
    

    com o seguinte código:

    variable ??= expression;
    

Capacidade de sobrecarga do operador

Os operadores ?? e ??= não pode ser sobrecarregado.

Especificação da linguagem C#

Para obter mais informações sobre o ?? operador, consulte a seção O operador de coalescência nulo da especificação da linguagem C#.

Para obter mais informações sobre o ??= operador, consulte a nota de proposta de recurso.

Consulte também