is(C# 참조)

업데이트: 2007년 11월

지정된 형식과 개체가 호환되는지 검사합니다. 예를 들어 다음 코드에서는 개체가 MyObject 형식의 인스턴스이거나 MyObject에서 파생된 형식인지 확인할 수 있습니다.

if (obj is MyObject)
{
}

지정된 식이 null이 아니고 예외를 throw하지 않은 채 지정된 개체를 지정된 형식으로 캐스팅할 수 있는 경우 is 식은 true가 됩니다.

식이 항상 true이거나 항상 false인 것으로 알려져 있는 경우 is 키워드는 컴파일 타임 경고를 발생시키지만 런타임에는 일반적으로 형식 호환성을 확인합니다.

is 연산자는 오버로드되지 않습니다.

is 연산자는 참조 변환, boxing 변환 및 unboxing 변환만 고려하고 사용자 정의 변환 같은 다른 변환은 고려되지 않습니다.

무명 메서드는 is 연산자의 왼쪽에 사용할 수 없습니다. 이 예외에는 람다 식이 포함됩니다.

예제

class Class1 {}
class Class2 {}
class Class3 : Class2 { }

class IsTest
{
    static void Test(object o)
    {
        Class1 a;
        Class2 b;

        if (o is Class1)
        {
            Console.WriteLine("o is Class1");
            a = (Class1)o;
            // Do something with "a."
        }
        else if (o is Class2)
        {
            Console.WriteLine("o is Class2");
            b = (Class2)o;
            // Do something with "b."
        }

        else
        {
            Console.WriteLine("o is neither Class1 nor Class2.");
        }
    }
    static void Main()
    {
        Class1 c1 = new Class1();
        Class2 c2 = new Class2();
        Class3 c3 = new Class3();
        Test(c1);
        Test(c2);
        Test(c3);
        Test("a string");
    }
}
/*
Output:
o is Class1
o is Class2
o is Class2
o is neither Class1 nor Class2.
*/

C# 언어 사양

자세한 내용은 C# 언어 사양의 다음 단원을 참조하십시오.

  • 7.6.6 캐스트 식

  • 7.9.10 is 연산자

참고 항목

개념

C# 프로그래밍 가이드

참조

C# 키워드

typeof(C# 참조)

as(C# 참조)

연산자 키워드(C# 참조)

기타 리소스

C# 참조