Dela via


is operator (C#-referens)

Operatorn is kontrollerar om resultatet av ett uttryck är kompatibelt med en viss typ. Information om typtestningsoperatorn is finns i avsnittet is operator i artikeln Type-testing and cast operators (operatorer för typtestning och gjutna operatorer ). Du kan också använda operatorn is för att matcha ett uttryck mot ett mönster, vilket visas i följande exempel:

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

I föregående exempel matchar operatorn is ett uttryck mot ett egenskapsmönster med kapslade konstant - och relationsmönster .

Operatorn is kan vara användbar i följande scenarier:

  • Så här kontrollerar du körningstypen för ett uttryck, vilket visas i följande exempel:

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

    Föregående exempel visar användningen av ett deklarationsmönster.

  • För att söka efter null, som följande exempel visar:

    if (input is null)
    {
        return;
    }
    

    När du matchar ett uttryck mot nullgaranterar kompilatorn att ingen överlagrad == användare eller != operator anropas.

  • Du kan använda ett negationsmönster för att göra en icke-null-kontroll, som följande exempel visar:

    if (result is not null)
    {
        Console.WriteLine(result.ToString());
    }
    
  • Från och med C# 11 kan du använda listmönster för att matcha element i en lista eller matris. Följande kod kontrollerar matriser efter heltalsvärden i förväntade positioner:

    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
    

Kommentar

En fullständig lista över mönster som stöds av operatorn finns i is Mönster.

Språkspecifikation för C#

Mer information finns i avsnittet is-operator i C#-språkspecifikationenoch Mönstermatchning.

Se även