다음을 통해 공유


__try_cast

참고   이 항목은 Managed Extensions for C++ 버전 1에만 적용됩니다. 이 구문은 버전 1 코드를 유지하기 위해서만 사용해야 합니다. 새 구문에서 동일한 기능을 사용하는 방법에 대한 자세한 내용은 safe_cast를 참조하십시오.

지정된 캐스트를 수행하거나 캐스트가 실패한 경우 예외를 throw합니다.

__try_cast < type-id > ( expression )

설명

__try_cast 키워드(dynamic_cast와 동작이 유사함)는 지정된 캐스팅 연산이 실패할 때마다 자동으로 System::InvalidCastException 형식의 예외를 throw하도록 지원합니다.

응용 프로그램의 테스트 단계 중에 __try_cast 키워드를 사용하여 가능한 캐스팅 실패에 대해 자동으로 경고할 수 있습니다.

Managed Extensions for C++를 이식하는 경우 __try_cast 호출을 safe_cast로 바꾸십시오.

__try_cast는 값 형식(__value)에 대한 포인터의 캐스트에서 작동하지 않습니다. 그 이유는 런타임에 해당 형식을 확인할 수 없기 때문입니다.

예제

다음 예제에서는 포인터(Derived 형식)를 다른 포인터(MoreDerived 형식)로 캐스팅하려고 합니다. 캐스팅에 실패하면 catch 블록에서 catch되어 보고됩니다.

// keyword__try_cast.cpp
// compile with: /clr:oldSyntax
#using <mscorlib.dll>
using namespace System;

__gc struct Base {}; 
__gc struct Derived : Base {};
__gc struct MoreDerived : Derived {};

int main() {
   Base*bp = new Derived;
   try {
       MoreDerived* mdp = __try_cast<MoreDerived*>(bp);
   }
   catch(System::InvalidCastException*) {
       Console::WriteLine("Could not cast 'bp' to MoreDerived*");
   }
}

Output

Could not cast 'bp' to MoreDerived*