__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*