Comment faire pour implémenter un modèle de mises en commun de thread cloisonné serveur COM dans ATL

Traductions disponibles Traductions disponibles
Numéro d'article: 244495 - Voir les produits auxquels s'applique cet article
Agrandir tout | Réduire tout

Résumé

Le Microsoft Template Library ATL (Active) permet de définir un pool de threads STA en un ATL de serveur de traitement avec chaque objet créé Exécution sur son propre thread. Les étapes de la section « Plus d'informations » de cet article explique comment procéder.

Plus d'informations

Les étapes suivantes sont nécessaires pour créer des objets d'un pool de threads :
  1. Dériver votre classe CExeModule ou CServiceModule de :
    CComAutoThreadModule<>
    					
    CExeModule : public CComAutoThreadModule<>
    					
  2. Déclarez DECLARE_CLASSFACTORY_AUTO_THREAD() dans chaque classe ATL qui peut être exécuté sur un thread de pool STA
  3. Déclarez DECLARE_NOT_AGGREGATABLE() dans chaque classe ATL qui peut être exécuté sur un thread de pool STA
    DECLARE_NOT_AGGREGATABLE(CMyPooledObject)
    					
  4. Modifier le module CExeModule::Unlock() ou CServiceModule::Unlock() méthode à appeler :
    CComAutoThreadModule<>::Unlock()
    						
    LONG CExeModule::Unlock()
    {
       LONG l = CComAutoThreadModule<>::Unlock();
       if (l == 0)
       {
         bActivity = true;
         SetEvent(hEventShutdown); // tell monitor that we transitioned to zero
       }
       return l;
    }
    						
Si cela est fait pour un service, vous devez faire une étape plus. Modifier le code suivant à partir de :
inline void CServiceModule::Init(_ATL_OBJMAP_ENTRY* p, HINSTANCE h, UINT nServiceNameID, const GUID* plibid)
{
   CComModule::Init(p, h, plibid);
				
à:
inline void CServiceModule::Init(_ATL_OBJMAP_ENTRY* p, HINSTANCE h, UINT nServiceNameID, const GUID* plibid)
{
   CComAutoThreadModule<>::Init(p, h, plibid);
				
par défaut, ATL crée un pool de quatre threads par processeur. Vous pouvez modifier ceci dans l'appel _Module.Init() dans l'appel de fonction tWinMain() en spécifiant le nombre de threads dans la section facultative suite paramètre. Par défaut, CComAutoThreadModule utilise CComSimpleThreadAllocator comme L'allocateur de thread. CComSimpleThreadAllocator utilise un schéma alternée simple à la création des objets dans le pool de threads.

Références

Pour plus d'informations recherche DECLARE_CLASS_FACTORY_AUTO_THREAD() CComAutoThreadModule et MSDN (Microsoft Developer Network).

Pour plus d'informations, cliquez sur le numéro ci-dessous pour afficher l'article correspondant dans la Base de connaissances Microsoft :
202128 CORRECTIF : serveur ATL EXE CComAutoThreadModule peut se bloquer sur enregistrement

Propriétés

Numéro d'article: 244495 - Dernière mise à jour: jeudi 26 mai 2005 - Version: 3.0
Les informations contenues dans cet article s'appliquent au(x) produit(s) suivant(s):
  • Microsoft ActiveX Template Library 3.0 sur le système suivant
    • Microsoft Visual C++ 6.0 Édition Entreprise
    • Microsoft Visual C++ 6.0 Édition Professionnelle
    • Microsoft Visual C++, 32-bit Learning Edition 6.0
Mots-clés : 
kbmt kbarchitecture kbhowto kblocalsvr kbservice kbthread KB244495 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: 244495
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