is operátor (C# referencia)
Az is
operátor ellenőrzi, hogy egy kifejezés eredménye kompatibilis-e egy adott típussal. A típustesztelő is
operátorral kapcsolatos információkért tekintse meg a Típustesztelés és az öntött operátorok cikk is operátor szakaszát. Az operátorral is
egyezést is végezhet egy kifejezés mintával, ahogyan az az alábbi példában látható:
static bool IsFirstFridayOfOctober(DateTime date) =>
date is { Month: 10, Day: <=7, DayOfWeek: DayOfWeek.Friday };
Az előző példában az is
operátor egy tulajdonságmintával egyező kifejezést egy beágyazott állandóval és relációs mintával egyezik meg.
Az is
operátor a következő esetekben lehet hasznos:
Egy kifejezés futásidejű típusának ellenőrzéséhez az alábbi példában látható módon:
int i = 34; object iBoxed = i; int? jNullable = 42; if (iBoxed is int a && jNullable is int b) { Console.WriteLine(a + b); // output 76 }
Az előző példa egy deklarációs minta használatát mutatja be.
A kereséshez
null
az alábbi példában látható módon:if (input is null) { return; }
Ha megfelel egy kifejezésnek
null
, a fordító garantálja, hogy a rendszer nem hív meg felhasználó által túlterhelt==
vagy!=
operátort.A negation minta használatával nem null értékű ellenőrzést végezhet, ahogy az alábbi példa is mutatja:
if (result is not null) { Console.WriteLine(result.ToString()); }
A C# 11-től kezdődően listamintákat használhat egy lista vagy tömb elemeinek egyeztetéséhez. A következő kód ellenőrzi a tömböket a várt pozíciókban lévő egész számértékek esetében:
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
Feljegyzés
Az operátor által is
támogatott minták teljes listáját a Minták című témakörben találja.
C# nyelvspecifikáció
További információ: A C#-nyelv specifikációjának és a mintaegyezésnek Az operátor szakasza.