CORRECTIF : EXE ATL Server basé sur CComAutoThreadModule peut se bloquer sur l'inscription

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.

202128
Cet article a été archivé. Il est proposé « en l'état » et ne sera plus mis à jour.
Symptômes
Un serveur ATL EXE basé sur CComAutoThreadModule <>peut se bloquer lorsque qui est enregistré ou non.
Cause
CComAutoThreadModule<>::Init() appelé dans WinMain() crée un pool de threads (par défaut 4 threads). Le destructeur de CComAutoThreadModule global rend certain de que ces threads se terminer avant le processus se termine. Cela se produit en envoyant message WM_QUIT à chacun des threads dans le pool de threads et l'appel à WaitForSingleObject() sur le handle du thread. Les threads sont planifiés telles que les threads du pool ne peuvent pas avoir appelé GetMessage() et donc la file d'attente de messages n'est pas créé. Cela provoque la PostThreadMessage() échec. Par conséquent, les threads du pool ne met pas fin et WaitForSingleObject() attend indéfiniment de threads à terminer.
Résolution
Dans le fichier Altcom.h, à l'intérieur du répertoire vc98\atl\include du destructeur dans la fonction CComAutoThreadModule, remplacez le code suivant :
   ::PostThreadMessage(m_pApartments[i].m_dwThreadID, WM_QUIT, 0, 0);				

avec ce code :
   while (::PostThreadMessage(m_pApartments[i].m_dwThreadID, WM_QUIT,      0, 0) == 0) ::Sleep(100);				
Statut
Microsoft a confirmé l'existence de ce bogue dans les produits Microsoft répertoriés au début de cet article.

Ce problème a été corrigé dans Microsoft Visual C++ .NET.
Plus d'informations
  1. Utiliser AppWizard pour créer un ATL EXE.
  2. Insérez n'importe quel type d'objet ATL dans le projet.
  3. Dans stdafx.h, remplacez CComModuleCComAutoThreadModule<ccomsimplethreadallocator>.
  4. Générez le projet.

    Remarque : il est probable que le serveur peut se bloquer à ce stade puisque l'étape de génération personnalisée inscrit le serveur.
  5. Dans le menu Paramètres du projet sous le type d'onglet Déboguer "/ RegServer» dans la boîte de dialogue Arguments du programme.
  6. Exécuter le serveur dans le débogueur.

    Remarque : si elle ne bloque pas la première fois, répétez cette étape. Dans la mesure où il s'agit de minutage lié, le problème ne peut pas reproduire sur certaines machines.
kbDSupport

Avertissement : Cet article a été traduit de manière automatique

Propriétés

ID d'article : 202128 - Dernière mise à jour : 01/06/2015 04:07:14 - Révision : 2.0

  • Microsoft ActiveX Template Library 3.0
  • kbnosurvey kbarchive kbmt kbbug kbfix kblocalsvr kbthread KB202128 KbMtfr
Commentaires