Megosztás:


Az 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.

A C# nyelv referenciadokumentuma a C# nyelv legújabb kiadású verzióját ismerteti. Emellett a közelgő nyelvi kiadás nyilvános előzetes verziójú funkcióinak kezdeti dokumentációját is tartalmazza.

A dokumentáció azonosítja azokat a funkciókat, amelyeket először a nyelv utolsó három verziójában vagy az aktuális nyilvános előzetes verziókban vezetnek be.

Jótanács

Ha meg szeretné tudni, hogy mikor jelent meg először egy funkció a C#-ban, tekintse meg a C# nyelvi verzióelőzményeiről szóló cikket.

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 nullaz 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.

  • Ha nem null értékű ellenőrzést szeretne végezni negációs mintával, az alábbi példában látható módon:

    if (result is not null)
    {
        Console.WriteLine(result.ToString());
    }
    
  • Lista vagy tömb elemeinek egyeztetése listaminták használatával. 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
    

Megjegyzé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ó: AC#-nyelv specifikációjának és a mintaegyezésnek Az operátor szakasza.

Lásd még