Operatore is (riferimenti per C#)

L'operatore is verifica se il risultato di un'espressione è compatibile con un determinato tipo. Per informazioni sull'operatore type-testingis, vedere la sezione relativa all'operatore is dell'articolo Operatori cast e test dei tipi. È anche possibile usare l'operatore is per trovare una corrispondenza tra un'espressione e un criterio, come illustrato nell'esempio seguente:

static bool IsFirstFridayOfOctober(DateTime date) =>
    date is { Month: 10, Day: <=7, DayOfWeek: DayOfWeek.Friday };

Nell'esempio precedente l'operatore corrisponde a un'espressione is rispetto a un modello di proprietà con modelli relazionali e costanti annidati.

L'operatore is può essere utile negli scenari seguenti:

  • Per controllare il tipo di runtime di un'espressione, come illustrato nell'esempio seguente:

    int i = 34;
    object iBoxed = i;
    int? jNullable = 42;
    if (iBoxed is int a && jNullable is int b)
    {
        Console.WriteLine(a + b);  // output 76
    }
    

    Nell'esempio precedente viene illustrato l'uso di un modello di dichiarazione.

  • Per verificare la presenza nulldi , come illustrato nell'esempio seguente:

    if (input is null)
    {
        return;
    }
    

    Quando si trova una corrispondenza tra un'espressione e null, il compilatore garantisce che non venga richiamato == alcun operatore o != overload dell'utente.

  • È possibile usare un modello di negazione per eseguire un controllo non Null, come illustrato nell'esempio seguente:

    if (result is not null)
    {
        Console.WriteLine(result.ToString());
    }
    
  • A partire da C# 11, è possibile usare modelli di elenco per trovare le corrispondenze con gli elementi di un elenco o di una matrice. Il codice seguente controlla le matrici per i valori integer nelle posizioni previste:

    int[] empty = [];
    int[] one = [1];
    int[] odd = [1, 3, 5];
    int[] even = [2, 4, 6];
    int[] fib = [1, 1, 2, 3, 5];
    
    Console.WriteLine(odd is [1, _, 2, ..]);   // false
    Console.WriteLine(fib is [1, _, 2, ..]);   // true
    Console.WriteLine(fib is [_, 1, 2, 3, ..]);     // true
    Console.WriteLine(fib is [.., 1, 2, 3, _ ]);     // true
    Console.WriteLine(even is [2, _, 6]);     // true
    Console.WriteLine(even is [2, .., 6]);    // true
    Console.WriteLine(odd is [.., 3, 5]); // true
    Console.WriteLine(even is [.., 3, 5]); // false
    Console.WriteLine(fib is [.., 3, 5]); // true
    

Nota

Per l'elenco completo dei modelli supportati dall'operatore is , vedere Modelli.

Specifiche del linguaggio C#

Per altre informazioni, vedere La sezione relativa all'operatore is della specifica del linguaggio C# e criteri di ricerca corrispondenti.

Vedi anche