Оригинальный DVD-ROM: eXeL@B DVD !
eXeL@B ВИДЕОКУРС !

ВИДЕОКУРС ВЗЛОМ
выпущен 1 марта!


УЗНАТЬ БОЛЬШЕ >>
Домой | Статьи | RAR-cтатьи | FAQ | Форум | Скачать | Видеокурс
Новичку | Ссылки | Программирование | Интервью | Архив | Связь

ПРОГРАММИРОВАНИЕ НА C и С++



Возможности языков семейства Си по истине безграничны, однако, в этой свободе кроются и недостатки: всегда нужно программисту держать ухо востро и контроллировать "переполнение буфера", чтобы потом программа не вылетала в "синий экран" на массе разнообразных версий Windows и железа у пользователей. Те же крэкеры и реверсеры специально ищут в коде программ на Си уязвимости, куда можно подсадить любой вирусный код, об этом более подробно автор рассказывал в своём видеокурсе здесь. Я там многое узнал и теперь мой код стал значительно более безопасный.

Как использовать GetExitCodeProcess() вместо IsTask()

В Windows 3.1, API функция IsTask() можно было использовать для определения запущен-ли всё ещё процесс или уже завершён. В Win32 API эта функция считается устаревшей.

В Win32 API для этих целей используется API функция GetExitCodeProcess(). Эта функция получает в качестве первого параметра дескриптор и возвращает код выхода либо STILL_ACTIVE во втором параметре:

   BOOL GetExitCodeProcess(hProcess, lpdwExitCode) 



   HANDLE hProcess;
    LPDWORD lpdwExitCode; 



Как альтернативу, можно так же использовать WaitForSingleObject(). Передаём дескриптор процесса в качестве первого параметра и значение таймаута в качестве второго:

   DWORD WaitForSingleObject(hObject, dwTimeout) 



   HANDLE hObject;
    DWORD dwTimeout; 



Дескриптор процесса сообщает, когда процесс завершён. Если мы хотим просто опросить, то в качестве таймаута надо передать 0 (ноль) либо запустить другой поток со значением таймаута INFINITE, чтобы ждать его завершения.



<< ВЕРНУТЬСЯ В ПОДРАЗДЕЛ

<< ВЕРНУТЬСЯ В ОГЛАВЛЕНИЕ




Материалы находятся на сайте https://exelab.ru/pro/



Оригинальный DVD-ROM: eXeL@B DVD !


Вы находитесь на EXELAB.rU
Проект ReactOS