Condividi tramite


__try_cast

Nota   Questo argomento si applica solo alla versione 1 delle estensioni gestite per C++. Questa sintassi deve essere utilizzata solo per gestire il codice della versione 1. Per informazioni sull'utilizzo della funzionalità equivalente nella nuova sintassi, vedere safe_cast (Estensioni del componente C++).

Esegue il cast specificato o genera un'eccezione se il cast non riesce.

__try_cast < type-id > ( expression )

Note

La parola chiave __try_cast (simile nel comportamento a dynamic_cast) fornisce supporto per generare automaticamente un'eccezione (di tipo System::InvalidCastException) ogni volta che l'operazione di cast specificata ha esito negativo.

La parola chiave __try_cast può essere utilizzata durante la fase di test dell'applicazione, avvisando automaticamente riguardo a errori di cast possibili.

Durante il trasferimento di estensioni gestite per C++, sostituire chiamate __try_cast con safe_cast (Estensioni del componente C++).

__try_cast non funziona in cast di puntatore a tipi di valore (__value), poiché non è possibile controllare i tipi in fase di esecuzione.

Esempio

Nell'esempio seguente, viene effettuato un tentativo di eseguire il cast di un puntatore (del tipo Derived) a un altro puntatore (di tipo MoreDerived). Se il cast ha esito negativo, viene intercettato e segnalato dal blocco 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*