Создание потоков


Функция CreateThread создает для процесса новый поток. Созданный поток должен определить начальный адрес кода, с которого новый поток должен исполняться. Как правило, начальный адрес - это название функции, определенной в коде программы. Эта функция получает единственный параметр и возвращает значение типа DWORD. Процесс может иметь одновременно несколько потоков, выполняющих ту же самую функцию.

Нижеследующий пример демонстрирует, как создать новый поток, который выполняет локально определяемую функцию ThreadFunc.

#include <windows.h>
#include <conio.h>

DWORD WINAPI ThreadFunc(LPVOID lpParam)

{

char szMsg[80];

wsprintf(szMsg, "Parameter = %d", *(DWORD*)lpParam);

MessageBox( NULL, szMsg, " ThreadFunc", MB_OK );

return 0;

}

VOID main( VOID )

{

DWORD dwThreadId, dwThrdParam = 1;

HANDLE hThread;

    char szMsg[80];

hThread = CreateThread(

NULL,         // атрибуты безопасности по умолчанию

0,            // размер стека используется по умолчанию

ThreadFunc,   // функция потока

&dwThrdParam, // аргумент функции потока

0,            // флажки создания используются по умолчанию

&dwThreadId); // возвращает идентификатор потока

// При успешном завершении проверяет возвращаемое значение.

if (hThread == NULL)

{
      wsprintf( szMsg, "CreateThread failed." ); 
      MessageBox( NULL, szMsg, "main", MB_OK );
   }
   else 
   {
      _getch();
      CloseHandle( hThread );
   }
} 

Для простоты, этот пример передает указатель на значение как на параметр функции потока. Это может быть указатель на любой тип данных или структуру, или это может быть пропущено совсем, при помощи передачи указателя NULL и удаления ссылок на параметр в ThreadFunc.

Опасно передавать адрес локальной переменной, если создающий поток заканчивает работу перед созданием нового потока, потому что указатель становится недопустимым. Вместо этого, или передайте указатель в динамически распределяемую память, или заставьте создающий поток ждать до тех пор, пока новый поток не завершит свое формирование. Данные могут также быть переданы и из создающего потока в новый поток, используя глобальные переменные. С глобальными переменными, обычно необходимо синхронизировать доступ ко многим потокам. Для получения дополнительной информации о синхронизации, см. статью Синхронизация исполнения многопоточного режима.

В процессах, где поток мог бы создать несколько потоков, чтобы исполнить некоторый код, неудобно использовать глобальные переменные. Например, процесс, который разрешает пользователю открыть одновременно несколько файлов на некоторое время, может создавать новый поток для каждого файла, с целью, чтобы каждый из потоков выполнял некоторую функцию потока. Создающий поток может передавать уникальную информацию (такую как имя файла) требующуюся для каждого экземпляра функции потока как параметр. Вы не можете использовать единственную глобальную переменную для этой цели, но Вы можете использовать динамически распределяемый строковый буфер.

Создающий поток может использовать параметры функции CreateThread, чтобы определить нижеследующее:

Вы можете также создать поток и путем вызова функции CreateRemoteThread. Эта функция используется процессами отладчика, чтобы создать поток, который запускается в адресном пространстве отлаживаемого процесса.

Назад в оглавление темы
На главную страницу темы

Hosted by uCoz