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
null
di , 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
Commenti e suggerimenti
Invia e visualizza il feedback per