Microsoft Windows CE 3.0  

TerminateProcess

Important:
This is retired content. This content is outdated and is no longer being maintained. It is provided as a courtesy for individuals who are still using these technologies. This content may contain URLs that were valid when originally published, but now link to sites or pages that no longer exist.

This function terminates the specified process and all of its threads.

BOOL
TerminateProcess(
HANDLE
hProcess
,
DWORD
uExitCode
);

Parameters

hProcess
Handle to the process to terminate.
uExitCode
Specifies the exit code for the process and for all threads terminated as a result of this call. Use the GetExitCodeProcessfunction to retrieve the process's exit value. Use the GetExitCodeThreadfunction to retrieve a thread's exit value.

Return Values

Nonzero indicates success. Zero indicates failure. To get extended error information, call GetLastError.

Remarks

The TerminateProcessfunction is used to unconditionally cause a process to exit. Use it only in extreme circumstances. The state of global data maintained by dynamic-link libraries (DLLs) may be compromised if TerminateProcess.

TerminateProcesscauses all threads within a process to terminate, and causes a process to exit, but DLLs attached to the process are not notified that the process is terminating.

Terminating a process causes the following:

  1. All of the object handles opened by the process are closed.
  2. All of the threads in the process terminate their execution.
  3. The state of the process object becomes signaled, satisfying any threads that had been waiting for the process to terminate.
  4. The states of all threads of the process become signaled, satisfying any threads that had been waiting for the threads to terminate.
  5. The termination status of the process changes from STILL_ACTIVE to the exit value of the process.

    Terminating a process does not cause child processes to be terminated.

    Terminating a process does not necessarily remove the process object from the system. A process object is deleted when the last handle to the process is closed.

    For Windows CE version 1.0, the uExitCodeparameter is ignored because process exit codes are not supported.

    Requirements

    Runs on Versions Defined in Include Link to
    Windows CE OS 1.0 and later Winbase.h   Coredll.lib
    Note   This API is part of the complete Windows CE OS package as provided by Microsoft. The functionality of a particular platform is determined by the original equipment manufacturer (OEM) and some devices may not support this API.

    See Also

    GetExitCodeProcess, GetExitCodeThread, GetLastError