Вопрос по c++, winapi – Необработанная ошибка с CreateProcess [duplicate]

5

This question already has an answer here:

CreateProcess method ends up with an error 1 answer

Я читал о функции CreateProcess в C ++, и я хотел попробовать это. Основная идея кода заключается в том, чтобы мой основной выполнял другой процесс (блокнот). На самом деле, это просто основной код. Когда я запускаю программу, я получаю:

First-chance exception at 0x752bb763 in createprocess.exe: 0xC0000005: Access violation writing location 0x00be57b8.
Unhandled exception at 0x752bb763 in createprocess.exe: 0xC0000005: Access violation writing location 0x00be57b8.

Когда я делаю точку останова, где происходит ошибка, я попадаю в tidtable.c (я думаю, для доступа к потокам). В частности, в tidtable.c наCRTIMP PFLS_GETVALUE_FUNCTION __cdecl __set_flsgetvalue() Я действительно не знаю, что и как избежать этой проблемы. Ошибка возникает при вызове CreateProcess (т. Е. Он никогда не выводит & # x201C; из create & # x201D;).

Мой код:

<code>#include "stdafx.h"
#include <stdio.h>
#include <windows.h>
#include <strsafe.h>
#include <direct.h>
#include <string.h>
#include <conio.h>

int main(VOID)
{
    STARTUPINFO si;
    PROCESS_INFORMATION pi;

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


fprintf(stderr, "This is just a test");

//create child process
if (!CreateProcess(NULL,
    L"C:\\Windows\\Notepad.exe",
    NULL,
    NULL,
    FALSE,
    0,
    NULL,
    NULL,
    &si,
    &pi))
{
        fprintf(stderr, "create process failed");

        return -1;
}
fprintf(stderr, "out of create");

    //parent waits for child to complete
WaitForSingleObject(pi.hProcess, INFINITE);

fprintf(stderr, "after wait");

printf("Child Complete");

    //close handle
CloseHandle(pi.hProcess);
//  CloseHandle(pi.hthread);

}
</code>

Если кто-нибудь знает, как преодолеть эту проблему, ваша помощь будет принята с благодарностью.

Увидетьblogs.msdn.com/b/oldnewthing/archive/2009/06/01/9673254.aspx Я отредактировал это в ответе Эрвина. 0xC0000022L

Ваш Ответ

2   ответа
17

CreateProcess Функция является параметром входа / выхода.

Если вы укажете ее как строку, как вы это сделали, это будет константная строка, и функция при ее вызове не сможет записать в ячейку памяти, что приведет к нарушению доступа к памяти. Правильный способ - вызвать вашу функцию следующим образом:

LPTSTR szCmdline = _tcsdup(TEXT("C:\\Windows\\Notepad.exe"));

//create child process
if (!CreateProcess(NULL,
    szCmdline,
    NULL,
    NULL,
    FALSE,
    0,
    NULL,
    NULL,
    &si,
    &pi))
{
    fprintf(stderr, "create process failed");

    return -1;
}

Вы также можете прочитатьэта статья блога.

Спасибо Эрвину, что решил это! Favn Hghksd
Теперь я раскомментировал последнюю строку кода: CloseHandle (pi.hthread), но я получаю эту ошибку: ошибка C2039: & h; : не является участником "_PROCESS_INFORMATION". Как мне это исправить. И благодарю вас Favn Hghksd
Это опечатка. CloseHandle (pi.hThread); C ++ чувствителен к регистру. Поэтому, пожалуйста, позаботьтесь о деле.
Вы можете использовать intellisense, чтобы помочь вам.
Согласно документации, только юникодная версия функции пытается изменить строку. Поскольку в этом случае вам, похоже, не нужен юникод, вы также можете явно использовать версию ANSI CreateProcessA.
1

2-й аргумент CreateProcess не может быть константой или литеральной строкой, потому что функция пытается изменить строку.т.

Только для версии Unicode! В версии ANSI этого нет, поскольку буфер с преобразованной строкой всегда доступен для записи.

Похожие вопросы