プロセスを作成する

CreateProcess 関数は、作成プロセスとは無関係に実行される新しいプロセスを作成します。 わかりやすくするために、このリレーションシップは親子リレーションシップと呼ばれます。

次のコードは、プロセスを作成する方法を示しています。

#include <windows.h>
#include <stdio.h>
#include <tchar.h>

void _tmain( int argc, TCHAR *argv[] )
{
    STARTUPINFO si;
    PROCESS_INFORMATION pi;

    ZeroMemory( &si, sizeof(si) );
    si.cb = sizeof(si);
    ZeroMemory( &pi, sizeof(pi) );

    if( argc != 2 )
    {
        printf("Usage: %s [cmdline]\n", argv[0]);
        return;
    }

    // Start the child process. 
    if( !CreateProcess( NULL,   // No module name (use command line)
        argv[1],        // Command line
        NULL,           // Process handle not inheritable
        NULL,           // Thread handle not inheritable
        FALSE,          // Set handle inheritance to FALSE
        0,              // No creation flags
        NULL,           // Use parent's environment block
        NULL,           // Use parent's starting directory 
        &si,            // Pointer to STARTUPINFO structure
        &pi )           // Pointer to PROCESS_INFORMATION structure
    ) 
    {
        printf( "CreateProcess failed (%d).\n", GetLastError() );
        return;
    }

    // Wait until child process exits.
    WaitForSingleObject( pi.hProcess, INFINITE );

    // Close process and thread handles. 
    CloseHandle( pi.hProcess );
    CloseHandle( pi.hThread );
}

CreateProcess が成功すると、新しいプロセスとそのプライマリ スレッドのハンドルと識別子を含むPROCESS_INFORMATION構造体が返されます。 スレッド ハンドルとプロセス ハンドルはフル アクセス権で作成されますが、セキュリティ記述子を指定した場合はアクセスを制限できます。 これらのハンドルが不要になったら、 CloseHandle 関数を使用してそれらを閉じます。

CreateProcessAsUser 関数または CreateProcessWithLogonW 関数を使用してプロセスを作成することもできます。 これらの関数を使用すると、プロセスを実行するユーザー アカウントのセキュリティ コンテキストを指定できます。