Wie Sie die # Import-Ausnahme auslösen Mechanismus für ActiveX Data Objects (ADO) in Visual C++ ersetzen

SPRACHE AUSWÄHLEN SPRACHE AUSWÄHLEN
Artikel-ID: 177425 - Produkte anzeigen, auf die sich dieser Artikel bezieht
Dieser Artikel wurde archiviert. Er wird im vorliegenden Zustand bereitgestellt und nicht mehr aktualisiert.
Hinweis: Microsoft Visual C++ .NET 2002 und Microsoft Visual C++ .NET 2003 unterstützen sowohl das verwaltete Codemodell, das von Microsoft .NET Framework zur Verfügung gestellt wird als auch nicht verwaltete systemeigene Microsoft Windows-Codemodell. Die Informationen in diesem Artikel beziehen sich nur auf nicht verwalteten Visual C++-Code.Microsoft Visual C++ .NET 2005 unterstützt das verwaltete Codemodell, das von Microsoft .NET Framework bereitgestellt wird und nicht verwaltete systemeigene Microsoft Windows-Codemodell.
Alles erweitern | Alles schließen

Auf dieser Seite

Zusammenfassung

Mithilfe der # Import-Anweisung zum Erstellen einer Clientanwendung führt Ausnahmebehandlung durch die Klasse _com_error Ausnahme stößt ein Wrapper für-Methode eines Objekts eine fehlgeschlagene HRESULT. Möglicherweise haben Sie Gründe für diesen Mechanismus durch eine eigene Implementierung ersetzen.

Weitere Informationen

Es gibt zwei Möglichkeiten, # Import verwenden und keinen es Ausnahmen für fehlgeschlagene HRESULTS auslösen. Der erste ist einfach, die Raw_interfaces_only-Klausel mit # Import-Anweisung zu verwenden. Diese negiert jedoch einige der Vorteile von Wrapperklassen, die # Import bereitstellt.

Beim zweiten Verfahren wird Ihre eigene Implementierung für _com_raise_error, über die folgende Prototyp und die Standard-Implementierung bereitstellen:

   void __stdcall _com_raise_error(HRESULT hr, IErrorInfo* perrinfo = 0)
   throw(_com_error);

   void __stdcall
   _com_raise_error(HRESULT hr, IErrorInfo* perrinfo = 0) throw(_com_error)
   {
       throw _com_error(hr, perrinfo);
   }
				
Diese Funktion wird deklariert, jedoch nicht in der Datei Comdef.h implementiert. Wenn Sie eine eigene Implementierung in einer .obj-Datei angeben, verwendet der Linker diese Implementierung im Gegensatz zu schalten es aus der Datei comsupp.lib in. _com_raise_error ist in ein eigenes Objekt in der comsupp.lib-Datei vorhanden, damit es von Ihrem Code einfach ersetzt werden kann.

Folgendes ist eine Beispielimplementierung von der # Import-Ausnahme auslösen Funktion.

Hinweis : zurzeit der Compiler eine Funktion-Ausnahmespezifikation ignoriert, und generiert die folgende Warnmeldung:

Warnung C4290: C++-Ausnahmespezifikation ignoriert.
Zu diesem Zeitpunkt haben die Implementierungsdetails der Ausnahmespezifikation nicht standardisiert wurde und werden akzeptiert jedoch nicht in Microsoft Visual C++ implementiert. Mit ignoriert Ausnahmespezifikationen kompiliert Code müssen möglicherweise neu kompiliert und verknüpft in zukünftigen Versionen, die Ausnahmespezifikationen unterstützen wiederverwendet werden. Sie können diese Warnung vermeiden, indem Sie das Pragma Warning:

#pragma warning( disable : 4290 ) 
				

Beispielcode

   void __stdcall
   _com_raise_error(HRESULT hr, IErrorInfo* perrinfo = 0) 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 <msado15.dll>
        ...


     _bstr_t     bstrEmpty(L"");
     _ConnectionPtr  Conn1 = NULL;
     Conn1.CreateInstance( __uuidof( Connection ) );
     Conn1->Open( bstrEmpty, bstrEmpty, bstrEmpty );

				
Dieser Code versucht, ein Verbindungsobjekt (ActiveX Data Objects) zu öffnen, ohne eine beliebige gültige Verbindungsinformationen. Ersetzen _com_raise_error verhindert, dass der _com_error ausgelöst wird.

Eigenschaften

Artikel-ID: 177425 - Geändert am: Samstag, 22. Februar 2014 - Version: 4.0
Die Informationen in diesem Artikel beziehen sich auf:
  • Microsoft Visual C++ 5.0 Enterprise Edition
  • Microsoft Visual C++ 6.0 Enterprise Edition
  • Microsoft Visual C++ 5.0 Professional Edition
  • Microsoft Visual C++ 6.0 Professional Edition
  • Microsoft Visual C++, 32-bit Learning Edition 6.0
  • Microsoft Visual C++ 2005 Express Edition
  • Microsoft Visual C++ .NET 2003 Standard Edition
  • Microsoft Visual C++ .NET 2002 Standard Edition
Keywords: 
kbnosurvey kbarchive kbmt kbhowto kbcompiler kbdatabase kbinfo kbmdacnosweep KB177425 KbMtde
Maschinell übersetzter Artikel
Wichtig: Dieser Artikel wurde maschinell und nicht von einem Menschen übersetzt. Die Microsoft Knowledge Base ist sehr umfangreich und ihre Inhalte werden ständig ergänzt beziehungsweise überarbeitet. Um Ihnen dennoch alle Inhalte auf Deutsch anbieten zu können, werden viele Artikel nicht von Menschen, sondern von Übersetzungsprogrammen übersetzt, die kontinuierlich optimiert werden. Doch noch sind maschinell übersetzte Texte in der Regel nicht perfekt, insbesondere hinsichtlich Grammatik und des Einsatzes von Fremdwörtern sowie Fachbegriffen. Microsoft übernimmt keine Gewähr für die sprachliche Qualität oder die technische Richtigkeit der Übersetzungen und ist nicht für Probleme haftbar, die direkt oder indirekt durch Übersetzungsfehler oder die Verwendung der übersetzten Inhalte durch Kunden entstehen könnten.
Den englischen Originalartikel können Sie über folgenden Link abrufen: 177425
Microsoft stellt Ihnen die in der Knowledge Base angebotenen Artikel und Informationen als Service-Leistung zur Verfügung. Microsoft übernimmt keinerlei Gewährleistung dafür, dass die angebotenen Artikel und Informationen auch in Ihrer Einsatzumgebung die erwünschten Ergebnisse erzielen. Die Entscheidung darüber, ob und in welcher Form Sie die angebotenen Artikel und Informationen nutzen, liegt daher allein bei Ihnen. Mit Ausnahme der gesetzlichen Haftung für Vorsatz ist jede Haftung von Microsoft im Zusammenhang mit Ihrer Nutzung dieser Artikel oder Informationen ausgeschlossen.

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