Partager via


IDebugClient ::CreateProcessAndAttach, méthode (dbgeng.h)

La méthode CreateProcessAndAttach crée un processus à partir d’une ligne de commande spécifiée, puis l’attache à un autre processus en mode utilisateur. Le processus créé est suspendu et autorisé à s’exécuter uniquement lorsque l’attachement est terminé. Cela permet une synchronisation approximative lors du débogage des processus client et serveur.

Syntaxe

HRESULT CreateProcessAndAttach(
  [in]           ULONG64 Server,
  [in, optional] PSTR    CommandLine,
  [in]           ULONG   CreateFlags,
  [in]           ULONG   ProcessId,
  [in]           ULONG   AttachFlags
);

Paramètres

[in] Server

Spécifie le serveur de processus à utiliser pour l’attacher au processus. Si serveur est égal à zéro, le moteur se connecte au processus local sans utiliser de serveur de processus.

[in, optional] CommandLine

Spécifie la ligne de commande à exécuter pour créer le nouveau processus. Si CommandLine est NULL, aucun processus n’est créé et ces méthodes s’attachent à un processus existant, comme AttachProcess le fait.

[in] CreateFlags

Spécifie les indicateurs à utiliser lors de la création du processus. Pour plus d’informations sur ces indicateurs, consultez DEBUG_CREATE_PROCESS_OPTIONS.CreateFlags.

[in] ProcessId

Spécifie l’ID de processus du processus cible auquel le débogueur est attaché. Si ProcessId est égal à zéro, le débogueur s’attache au processus qu’il a créé à partir de CommandLine .

[in] AttachFlags

Spécifie les indicateurs qui contrôlent la façon dont le débogueur s’attache au processus cible. Pour plus d’informations sur ces indicateurs, consultez DEBUG_ATTACH_XXX.

Valeur de retour

Cette méthode peut également retourner des valeurs d’erreur. Pour plus d’informations, consultez valeurs de retour.

Retourner le code Description
S_OK
La méthode a réussi.

Remarques

Cette méthode est disponible uniquement pour le débogage en mode utilisateur en direct.

Si CommandLine n’est pas NULL et ProcessId n’est pas zéro, le moteur crée le processus dans un état suspendu. Le moteur reprend ce processus nouvellement créé une fois qu’il se connecte correctement au processus spécifié dans ProcessId.

Remarque Le moteur n’est pas entièrement attaché au processus tant que la méthode WaitForEvent n’a pas été appelée. Une fois que le processus a généré un événement (par exemple, l’événement create-process) devient disponible dans la session du débogueur.
 
Pour plus d’informations sur la création et l’attachement à des cibles en mode utilisateur en direct, consultez Cibles live User-Mode.

Exigences

Exigence Valeur
plateforme cible Bureau
d’en-tête dbgeng.h (include Dbgeng.h)

Voir aussi

.attach (Attacher au processus)

.create (Créer un processus)

AbandonCurrentProcess

AttachProcess

ConnectProcessServer

CreateProcess2

CreateProcessAndAttach2

DetachCurrentProcess

GetRunningProcessDescription

GetRunningProcessSystemIds

IDebugClient

IDebugClient2

IDebugClient3

IDebugClient4

IDebugClient5

TerminateCurrentProcess