Procédure de remplacement d'exception du # Import déclenchement du mécanisme dans Visual C++

Traductions disponibles Traductions disponibles
Numéro d'article: 175784 - Voir les produits auxquels s'applique cet article
Cet article a été archivé. Il est proposé « en l'état » et ne sera plus mis à jour.
Remarque Microsoft Visual C++ .NET 2002 et Microsoft Visual C++ .NET 2003 prennent en charge le le modèle de code managé fourni par Microsoft .NET Framework et le modèle de code Microsoft Windows natif non managé. Les informations contenues dans cet article s'appliquent uniquement au code de Visual C++ non managé.Microsoft Visual C++ 2005 prend en charge le modèle de code managé qui est fourni par Microsoft .NET Framework et le modèle de code Microsoft Windows natif non managé.
Agrandir tout | Réduire tout

Résumé

L'utilisation de # import pour créer votre application cliente présente de gestion des exceptions par le biais de la classe exception _com_error lorsqu'un wrapper pour la méthode d'un objet rencontre un HRESULT ayant échoué. Vous pouvez avoir des raisons valables pour remplacer ce mécanisme par votre propre implémentation.

Plus d'informations

Il existe deux façons pour utiliser # Import et pas lever des exceptions pour les valeurs HRESULT d'échec. La première consiste à utiliser la clause raw_interfaces_only avec l'instruction # import. Toutefois, cela NIE quelques-uns des avantages des classes wrapper qui fournit de # import.

La seconde technique consiste à fournir votre propre implémentation pour _com_raise_error ayant l'implémentation de prototype et par défaut suivante :
void __stdcall _com_raise_error(HRESULT hr, IErrorInfo* perrinfo = 0)
   throw(_com_error);

   void __stdcall
   _com_raise_error(HRESULT hr, IErrorInfo* perrinfo ) throw(_com_error)
   {
       throw _com_error(hr, perrinfo);
   } 
				
cette fonction est déclarée mais non implémentée dans le fichier COMDEF.H. Si vous fournissez votre propre implémentation dans un .obj, l'éditeur de liens qui utilise au lieu de mettre à partir de COMSUPP.LIB. _com_raise_error présente dans son propre objet dans COMSUPP.LIB qu'il peut être aisément remplacé par votre code.

Voici un exemple de mise en oeuvre de la fonction de déclenchement exception de # import :
Remarque : Actuellement, notre compilateur ignore une spécification d'exception fonction et génère l'avertissement :
avertissement C4290: C++ spécification d'exception ignoré.
En fonction de C++ livre blanc si toute déclaration d'une fonction a une-spécification d'exception, toutes les déclarations, y compris la définition de cette fonction a une spécification d'exception avec le même jeu de type ID.
void __stdcall
   _com_raise_error(HRESULT hr, IErrorInfo* perrinfo ) throw(_com_error)
       {
           //this message box is for demonstration purpose only
          AfxMessageBox( "_com_raise_error (HRESULT, IErrorInfo*)" );
           //your own error handling code or just an abort
       }
#import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF", "adoEOF" )

       _bstr_t     bstrEmpty(L"");
       _ConnectionPtr  Conn1 = NULL;
       Conn1.CreateInstance( __uuidof( Connection ) );
       Conn1->Open( bstrEmpty, bstrEmpty, bstrEmpty,0 ); 
					
Ce code tente d'ouvrir un objet de connexion ADO sans fournir d'informations de connexion valide. En remplaçant _com_raise_error, vous pouvez pas le _com_error d'empêcher le déclenchement.

Toutefois, parce que vous avez remplacé cette fonction, vous devrez peut-être d'intercepter les exceptions. Envisagez l'extrait de code suivant.
#import "C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF", "adoEOF" )
    _ConnectionPtr  Conn1 = NULL;
    // Conn1.CreateInstance( __uuidof( Connection ) );
    Conn1->Open( bstrEmpty, bstrEmpty, bstrEmpty ,0); 
				
Dans ce cas, Conn1 n'est pas un objet valide et le pointeur d'interface vers cet objet inexistant est NULL, aboutissant à _com_raise_erro appelée. Toutefois, le surchargée-> opérateur méthode retournera une interface null, sur lequel le compilateur tente ensuite d'appeler la méthode Open(), ce qui entraîne une exception Win32. Conn1 test pour NULL tout d'abord avant d'appeler Open() empêcherait cette exception.

Propriétés

Numéro d'article: 175784 - Dernière mise à jour: samedi 1 mars 2014 - Version: 5.0
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft Visual C++ 2005 Express Edition
  • Microsoft Visual C++ .NET 2003 Initiation
  • Microsoft Visual C++ .NET 2002 Initiation
  • Microsoft Visual C++ 6.0 Édition Entreprise
  • Microsoft Visual C++ 6.0 Édition Professionnelle
  • Microsoft Visual C++, 32-bit Learning Edition 6.0
  • Microsoft Visual C++ 5.0 Édition Entreprise
  • Microsoft Visual C++ 5.0 Édition Professionnelle
Mots-clés : 
kbnosurvey kbarchive kbmt kbhowto kbdatabase kbinfo KB175784 KbMtfr
Traduction automatique
IMPORTANT : Cet article est issu du système de traduction automatique mis au point par Microsoft (http://support.microsoft.com/gp/mtdetails). Un certain nombre d?articles obtenus par traduction automatique sont en effet mis à votre disposition en complément des articles traduits en langue française par des traducteurs professionnels. Cela vous permet d?avoir accès, dans votre propre langue, à l?ensemble des articles de la base de connaissances rédigés originellement en langue anglaise. Les articles traduits automatiquement ne sont pas toujours parfaits et peuvent comporter des erreurs de vocabulaire, de syntaxe ou de grammaire (probablement semblables aux erreurs que ferait une personne étrangère s?exprimant dans votre langue !). Néanmoins, mis à part ces imperfections, ces articles devraient suffire à vous orienter et à vous aider à résoudre votre problème. Microsoft s?efforce aussi continuellement de faire évoluer son système de traduction automatique.
La version anglaise de cet article est la suivante: 175784
L'INFORMATION CONTENUE DANS CE DOCUMENT EST FOURNIE PAR MICROSOFT SANS GARANTIE D'AUCUNE SORTE, EXPLICITE OU IMPLICITE. L'UTILISATEUR ASSUME LE RISQUE DE L'UTILISATION DU CONTENU DE CE DOCUMENT. CE DOCUMENT NE PEUT ETRE REVENDU OU CEDE EN ECHANGE D'UN QUELCONQUE PROFIT.

Envoyer des commentaires

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com