Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Operátor (referenční dokumentace jazyka
Operátor is zkontroluje, jestli je výsledek výrazu kompatibilní s daným typem. Informace o operátoru testování is typu naleznete v části operátor testování typu a přetypování článku. Operátor můžete použít is také k porovnání výrazu se vzorem, jak ukazuje následující příklad:
static bool IsFirstFridayOfOctober(DateTime date) =>
date is { Month: 10, Day: <=7, DayOfWeek: DayOfWeek.Friday };
V předchozím příkladu is operátor odpovídá výrazu proti vzoru vlastnosti s vnořenými konstantními a relačními vzory.
Operátor is může být užitečný v následujících scénářích:
Pokud chcete zkontrolovat typ běhu výrazu, jak ukazuje následující příklad:
int i = 34; object iBoxed = i; int? jNullable = 42; if (iBoxed is int a && jNullable is int b) { Console.WriteLine(a + b); // output 76 }Předchozí příklad ukazuje použití vzoru deklarace.
Pokud chcete zkontrolovat
null, jak ukazuje následující příklad:if (input is null) { return; }Při porovnávání výrazu
nulls kompilátorem zaručuje, že se nevyvolá žádný přetížený==uživatel nebo!=operátor.Vzor negace můžete použít k provedení kontroly, která není null, jak ukazuje následující příklad:
if (result is not null) { Console.WriteLine(result.ToString()); }Vzory seznamu můžete použít ke shodě prvků seznamu nebo pole. Následující kód zkontroluje pole pro celočíselné hodnoty v očekávaných pozicích:
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
Poznámka:
Úplný seznam vzorů podporovaných operátorem is najdete v tématu Vzory.
Specifikace jazyka C#
Další informace naleznete v části Operátorspecifikace jazyka C# a porovnávání vzorů.