Sdílet prostřednictvím


CATCH

Definuje blok kódu, který zachycuje první typ výjimky v předchozím akci bloku.

CATCH(exception_class, exception_object_pointer_name )

Parametry

  • exception_class
    Určuje typ výjimky pro testování.Seznam výjimek standardní třídy, viz třída CException.

  • exception_object_pointer_name
    Určuje název pro objekt výjimky ukazatel, který vytvoří makro.Název ukazatele můžete použít pro přístup k objektu výjimky v rámci úlovku bloku.Tato proměnná je deklarován pro vás.

Poznámky

Kód zpracování výjimek mohou interrogate objekt výjimky, případně získat další informace o konkrétní příčinu výjimku.Vyvolat THROW_LAST posunout do dalšího rámečku výjimky vnější zpracování makra.Konec akci bloku se END_CATCH makro.

Pokud exception_class je třída CException, pak vzniká, všechny typy výjimek.Můžete použít CObject::IsKindOf určit, která zvláštní výjimka byla vyvolána členské funkce.Lepší způsob odlovu několik druhů výjimky je použití sekvenční AND_CATCH příkazy, každý typ různé výjimky.

Vytvoří ukazatel výjimka objektu makra.Není potřeba deklarovat sami.

[!POZNÁMKA]

Úlovku bloku je definována jako C++ oboru vymezen ve složených závorkách.Pokud deklarujete proměnné v tomto oboru, jsou přístupné pouze v daném oboru.To platí také pro exception_object_pointer_name.

Další informace o výjimky a úlovku makro, naleznete v článku výjimky.

Příklad

CFile* pFile = NULL;
// Constructing a CFile object with this override may throw
// a CFile exception and won't throw any other exceptions.
// Calling CString::Format() may throw a CMemoryException,
// so we have a catch block for such exceptions, too. Any
// other exception types this function throws will be
// routed to the calling function.
TRY
{
   pFile = new CFile(_T( "C:\\WINDOWS\\SYSTEM.INI"), 
      CFile::modeRead | CFile::shareDenyNone);
   ULONGLONG dwLength = pFile->GetLength();
   CString str;
   str.Format(_T("Your SYSTEM.INI file is %I64u bytes long.") , dwLength);
   AfxMessageBox(str);
}
CATCH(CFileException, pEx)
{
   // Simply show an error message to the user.
   pEx->ReportError();
}
AND_CATCH(CMemoryException, pEx)
{
   // We can't recover from this memory exception, so we'll
   // just terminate the app without any cleanup. Normally, 
   // an application should do everything it possibly can to
   // clean up properly and not call AfxAbort().
   AfxAbort();
}
END_CATCH
// If an exception occurs in the CFile constructor,
// the language will free the memory allocated by new
// and will not complete the assignment to pFile.
// Thus, our cleanup code needs to test for NULL.
if (pFile != NULL)
{
   pFile->Close();
   delete pFile;
}

Požadavky

Záhlaví: afx.h

Viz také

Referenční dokumentace

TRY

AND_CATCH

END_CATCH

THROW (MFC)

THROW_LAST

CATCH_ALL

Třída CException

Koncepty

MFC makra a Globals