Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.87/68: Рейтинг темы: голосов - 68, средняя оценка - 4.87
 Аватар для alexey31415
60 / 60 / 7
Регистрация: 16.05.2010
Сообщений: 632

Использование CreateThread

14.07.2012, 18:13. Показов 13883. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Создаю функцию для потока,запускаю её с помощью _beginthread и всё нормально работает,но если использовать CreateThread,то возникают ошибки
функция,используемая с
_beginthread

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#include "StdAfx.h"
 
//-----------------------------------------------------------------------
//функция для установления соединения,получения данных и записи их в файл
//-----------------------------------------------------------------------
 
//объявляем буфер, для хранения возможной ошибки, размер определяется в самой библиотеке
static char errorBuffer[CURL_ERROR_SIZE];
//объявляем буфер принимаемых данных
//static string buffer;
 
 
typedef struct
{
    string buffer;
}DATA, *PDATA;
 
//функция обратного вызова
static int writer(char *data, size_t size, size_t nmemb, string *buffer)
{
  //переменная - результат, по умолчанию нулевая
  int result = 0;
 
  if (buffer != NULL)
  {
    //добавляем к буферу строки из data, в количестве nmemb
    buffer->append(data, size * nmemb);
    //вычисляем объем принятых данных
    result = size * nmemb;
  }
  //вовзращаем результат
  return result;
}
 
 
 
void connect(PVOID pvoid)
{
    PINFO pinfo = (PINFO)pvoid;
 
    setlocale(0,"");
 
    DWORD dwTlsIndex = TlsAlloc();
 
    TlsSetValue(dwTlsIndex,GlobalAlloc(GPTR,sizeof(DATA)));
 
    PDATA pdata;
 
    pdata = (PDATA)TlsGetValue(dwTlsIndex);
 
    //необходимые CURL объекты
    CURL *curl;
    CURLcode result;
    //инициализируем curl
    curl = curl_easy_init();
 
    //проверяем результат инициализации
  if (curl)
    {
    curl_easy_setopt(curl, CURLOPT_ERRORBUFFER, errorBuffer);
      //задаем все необходимые опции
      curl_easy_setopt(curl, CURLOPT_URL,pinfo->url);
     
      curl_easy_setopt(curl, CURLOPT_HEADER, 0);         // не возвращает заголовки
      curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);   // переходит по редиректам
      curl_easy_setopt(curl, CURLOPT_ENCODING, "");        // обрабатывает все кодировки
 
      curl_easy_setopt(curl, CURLOPT_CONNECTTIMEOUT, 120); // таймаут соединения
      curl_easy_setopt(curl, CURLOPT_TIMEOUT, 120);        // таймаут ответа
      curl_easy_setopt(curl, CURLOPT_MAXREDIRS, 10);       // останавливаться после 10-ого редиректа
 
 
      //указываем функцию обратного вызова для записи получаемых данных
      curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, writer);
      //указываем куда записывать принимаемые данные
      curl_easy_setopt(curl, CURLOPT_WRITEDATA, &(pdata->buffer));
      //запускаем выполнение задачи
      result = curl_easy_perform(curl);
 
      //проверяем успешность выполнения операции
      if (result == CURLE_OK)
        {
        string fn(pinfo->NameOfFile);
        ofstream f(fn.c_str());
        if(!f) { MessageBox(pinfo->hwnd, "Can't create file","Error",MB_OK);}
        else   { f<<pdata->buffer<<endl; f.close();}
        }
  }
    else
    //выводим сообщение об ошибке
    MessageBox(pinfo->hwnd, "Can't connect","Error",MB_OK);
 
     
  //завершаем сессию
  curl_easy_cleanup(curl);
 
  TlsFree(dwTlsIndex);
 
  _endthread();
}
,а вот с
CreateThread

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include "StdAfx.h"
 
//-----------------------------------------------------------------------
//функция для установления соединения,получения данных и записи их в файл
//-----------------------------------------------------------------------
 
typedef struct
{
    string buffer;
    char errorBuffer[CURL_ERROR_SIZE];
    CURL *curl;
    CURLcode result;
}DATA, *PDATA;
 
//функция обратного вызова
static int writer(char *data, size_t size, size_t nmemb, string *buffer)
{
  //переменная - результат, по умолчанию нулевая
  int result = 0;
 
  if (buffer != NULL)
  {
    //добавляем к буферу строки из data, в количестве nmemb
    buffer->append(data, size * nmemb);
    //вычисляем объем принятых данных
    result = size * nmemb;
  }
  //вовзращаем результат
  return result;
}
 
 
DWORD WINAPI connect(LPVOID pvoid)
{
    PINFO pinfo = (PINFO)pvoid;
 
    setlocale(0,"");
 
    DWORD dwTlsIndex = TlsAlloc();
 
    TlsSetValue(dwTlsIndex,GlobalAlloc(GPTR,sizeof(DATA)));
 
    PDATA pdata;
 
    pdata = (PDATA)TlsGetValue(dwTlsIndex);
    
    
    //инициализируем curl
    pdata->curl = curl_easy_init();
 
    //проверяем результат инициализации
  if (pdata->curl)
    {
    curl_easy_setopt(pdata->curl, CURLOPT_ERRORBUFFER, pdata->errorBuffer);
      //задаем все необходимые опции
      curl_easy_setopt(pdata->curl, CURLOPT_URL,pinfo->url);
     
      curl_easy_setopt(pdata->curl, CURLOPT_HEADER, 0);         // не возвращает заголовки
      curl_easy_setopt(pdata->curl, CURLOPT_FOLLOWLOCATION, 1);   // переходит по редиректам
      curl_easy_setopt(pdata->curl, CURLOPT_ENCODING, "");        // обрабатывает все кодировки
 
      curl_easy_setopt(pdata->curl, CURLOPT_CONNECTTIMEOUT, 120); // таймаут соединения
      curl_easy_setopt(pdata->curl, CURLOPT_TIMEOUT, 120);        // таймаут ответа
      curl_easy_setopt(pdata->curl, CURLOPT_MAXREDIRS, 10);       // останавливаться после 10-ого редиректа
 
 
      //указываем функцию обратного вызова для записи получаемых данных
      curl_easy_setopt(pdata->curl, CURLOPT_WRITEFUNCTION, writer);
      //указываем куда записывать принимаемые данные
      curl_easy_setopt(pdata->curl, CURLOPT_WRITEDATA, &(pdata->buffer));
      //запускаем выполнение задачи
      pdata->result = curl_easy_perform(pdata->curl);
 
      //проверяем успешность выполнения операции
      if (pdata->result == CURLE_OK)
        {
        string fn(pinfo->NameOfFile);
        ofstream f(fn.c_str());
        if(!f) { MessageBox(pinfo->hwnd, "Can't create file","Error",MB_OK);}
        else   { f<<pdata->buffer<<endl; f.close();}
        }
  }
    else
    {
    //выводим сообщение об ошибке
    MessageBox(pinfo->hwnd, "Can't connect","Error",MB_OK);
    return false;
    }
     
  //завершаем сессию
  curl_easy_cleanup(pdata->curl);
 
  TlsFree(dwTlsIndex);
 
  return true;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.07.2012, 18:13
Ответы с готовыми решениями:

Struct в CreateThread
Здравствуйте. Имеется класс game: class game { private: ball *Ball; //Объект класса ball platform *Platform; //Объект...

createthread и closehandle
void func() { while(1) { printf(&quot;hello world&quot;); //:-D } } void main() {

CreateThread или beginthreadex
Как-то так повелось что при создании потока я использую ф-цию CreateThread. Тем не менее, все почему-то советуют пользоваться...

12
 Аватар для Aneron
166 / 164 / 27
Регистрация: 20.04.2010
Сообщений: 607
14.07.2012, 18:39
какая ошибка7 экстрасенсов нет.
0
 Аватар для alexey31415
60 / 60 / 7
Регистрация: 16.05.2010
Сообщений: 632
14.07.2012, 21:34  [ТС]
Цитата Сообщение от alexey31415 Посмотреть сообщение
curl_easy_setopt(pdata->curl, CURLOPT_ERRORBUFFER, pdata->errorBuffer);
вот здесь функция прерывается

Добавлено через 2 часа 50 минут
такж есть проблема с разделением потоков,после 3 вызовов CreateThread вызываю WaitForMultipleObjects,но вызываемые после этой функции 3 потока для выделения данных запускаются не по завершении первых трёх(для посылки запроса)
0
2838 / 1647 / 254
Регистрация: 03.12.2007
Сообщений: 4,222
14.07.2012, 22:48
_beginthread инициализирует сишную библиотеку (которая может использовать TLS), а CreateThread - нет. Если curl использует сишные функции, получаются проблемы.
0
290 / 193 / 23
Регистрация: 03.08.2011
Сообщений: 2,824
Записей в блоге: 12
14.07.2012, 23:29
alexey31415, вот рабочий пример

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


--------------------------------------------------------------------------------

Функция 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, чтобы определить нижеследующее:

Атрибуты системы безопасности для дескриптора нового потока. Эти атрибуты защиты включают в себя флажок наследования, который устанавливает, может ли дескриптор быть унаследован дочерними процессами. Атрибуты системы безопасности к тому же включают в себя дескриптор безопасности, который система использует, чтобы выполнить доступ, который контролирует все последующие использования дескриптора потока прежде, чем предоставляется обращение к нему.
Начальный размер стека нового потока. Стек потока назначается автоматически в пространстве памяти процесса; система увеличивает стек насколько необходимо и освобождает его, когда поток заканчивает работу. Дополнительную информацию см. в статье Размер стека потока.
Флажок создания, который разрешает Вам создать поток в состоянии ожидания. Когда произошла приостановка, поток не запускается до тех пор, пока не будет вызвана функция ResumeThread.
Вы можете также создать поток и путем вызова функции CreateRemoteThread. Эта функция используется процессами отладчика, чтобы создать поток, который запускается в адресном пространстве отлаживаемого процесса.

Назад в оглавление темы
На главную страницу темы
2
 Аватар для alexey31415
60 / 60 / 7
Регистрация: 16.05.2010
Сообщений: 632
15.07.2012, 00:32  [ТС]
Цитата Сообщение от Van111 Посмотреть сообщение
вот рабочий пример
я видел подобные примеры и сделал по аналогии,я ж потому тему и создал,что не нашёл решения
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
15.07.2012, 09:30
Ну думаю проблема не в потоках

Если на быструю руку, то приблизительно так. DLoader.rar

Не знаю как парсинг, но чисто загрузка у меня работает нормально.
0
 Аватар для alexey31415
60 / 60 / 7
Регистрация: 16.05.2010
Сообщений: 632
15.07.2012, 12:30  [ТС]
возможно у меня проблема возникает из-за добавления WaitForMultipleObjects,потому что мне нужно остановитть основной поток,пока работают потоки для загрузки,потом возобновить основной,запустить потоки для парсинга,опять остановить основной-дождаться и лишь затем заполнить списки
а у меня выходит так,запускаю программу,вылетает сообщение разрешение на установление соединения(это антивирус работает,ничего страшного),разрешаю-и создаётся лишь один файл,потом начинается парсинг и естетсвенно один открывается,а остальные два нет
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
15.07.2012, 17:47
Ну так код в студию с указанным WaitForMultipleObjects
0
 Аватар для alexey31415
60 / 60 / 7
Регистрация: 16.05.2010
Сообщений: 632
15.07.2012, 23:19  [ТС]
вот часть WndProc,где создаются потоки
WndProc
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
int i;
 
        //------------------------------------------------
        //получаем данные
        //------------------------------------------------
 
        for(i = 0;i < THREADCOUNT;i++)
        {
            aThread[i] = CreateThread(
                NULL,0,
                (LPTHREAD_START_ROUTINE)connect,
                NULL,
                0,
                &ThreadId);
        }
 
        WaitForMultipleObjects(THREADCOUNT, aThread, true,INFINITE);
 
        for(i = 0;i < THREADCOUNT;i++)
            CloseHandle(aThread[i]);
 
        //------------------------------------------------
        //извлекаем из xml файла
        //------------------------------------------------
    
        for(i = 0;i < THREADCOUNT;i++)
        {
            aThread[i] = CreateThread(
                NULL,0,
                (LPTHREAD_START_ROUTINE)parsing,
                NULL,
                0,
                &ThreadId);
        }
    
        WaitForMultipleObjects(THREADCOUNT, aThread, true,INFINITE);
 
        for(i = 0;i < THREADCOUNT;i++)
            CloseHandle(aThread[i]);

вот функция
connect
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include "StdAfx.h"
 
//-----------------------------------------------------------------------
//функция для установления соединения,получения данных и записи их в файл
//-----------------------------------------------------------------------
 
typedef struct
{
    string buffer;
    char errorBuffer[CURL_ERROR_SIZE];
    CURL *curl;
    CURLcode result;
}DATA, *PDATA;
 
//функция обратного вызова
static int writer(char *data, size_t size, size_t nmemb, string *buffer)
{
  //переменная - результат, по умолчанию нулевая
  int result = 0;
 
  if (buffer != NULL)
  {
    //добавляем к буферу строки из data, в количестве nmemb
    buffer->append(data, size * nmemb);
    //вычисляем объем принятых данных
    result = size * nmemb;
  }
  //вовзращаем результат
  return result;
}
 
 
DWORD WINAPI connect(LPVOID pvoid)
{
    PINFO pinfo = (PINFO)pvoid;
 
    DWORD dwTlsIndex = TlsAlloc();
 
    TlsSetValue(dwTlsIndex,GlobalAlloc(GPTR,sizeof(DATA)));
 
    PDATA pdata;
 
    pdata = (PDATA)TlsGetValue(dwTlsIndex);
 
    //инициализируем curl
    pdata->curl = curl_easy_init();
 
    //проверяем результат инициализации
  if (pdata->curl)
    {
    curl_easy_setopt(pdata->curl, CURLOPT_ERRORBUFFER, pdata->errorBuffer);
      //задаем все необходимые опции
      curl_easy_setopt(pdata->curl, CURLOPT_URL,pinfo->url);
     
      curl_easy_setopt(pdata->curl, CURLOPT_HEADER, 0);         // не возвращает заголовки
      curl_easy_setopt(pdata->curl, CURLOPT_FOLLOWLOCATION, 1);   // переходит по редиректам
      curl_easy_setopt(pdata->curl, CURLOPT_ENCODING, "");        // обрабатывает все кодировки
 
      curl_easy_setopt(pdata->curl, CURLOPT_CONNECTTIMEOUT, 120); // таймаут соединения
      curl_easy_setopt(pdata->curl, CURLOPT_TIMEOUT, 120);        // таймаут ответа
      curl_easy_setopt(pdata->curl, CURLOPT_MAXREDIRS, 10);       // останавливаться после 10-ого редиректа
 
 
      //указываем функцию обратного вызова для записи получаемых данных
      curl_easy_setopt(pdata->curl, CURLOPT_WRITEFUNCTION, writer);
      //указываем куда записывать принимаемые данные
      curl_easy_setopt(pdata->curl, CURLOPT_WRITEDATA, &(pdata->buffer));
      //запускаем выполнение задачи
      pdata->result = curl_easy_perform(pdata->curl);
 
      //проверяем успешность выполнения операции
      if (pdata->result == CURLE_OK)
        {
        string fn(pinfo->NameOfFile);
        ofstream f(fn.c_str());
        if(!f) { MessageBox(pinfo->hwnd, "Can't create file","Error",MB_OK);}
        else   { f<<pdata->buffer<<endl; f.close();}
        }
  }
    else
    {
    //выводим сообщение об ошибке
    MessageBox(pinfo->hwnd, "Can't connect","Error",MB_OK);
    return false;
    }
     
  //завершаем сессию
  curl_easy_cleanup(pdata->curl);
 
  TlsFree(dwTlsIndex);
 
  return true;
}

а вот
parsing
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#include "StdAfx.h"
 
extern NEWS source[15];
 
typedef struct
{
    TiXmlDocument *doc;
}DATA, *PDATA;
 
DWORD WINAPI parsing(PVOID pvoid)
{
    PINFO pinfo;
 
    pinfo = (PINFO)pvoid;
 
    DWORD dwTlsIndex = TlsAlloc();
 
    TlsSetValue(dwTlsIndex,GlobalAlloc(GPTR,sizeof(DATA)));
 
    PDATA pdata;
 
    pdata = (PDATA)TlsGetValue(dwTlsIndex);
 
    int Start  =  pinfo->Amount;
    int Finish = pinfo->Amount + 5;
 
    string temp(pinfo->NameOfFile);
 
    pdata->doc = new TiXmlDocument(temp.c_str());
 
    bool LoadOK = pdata->doc->LoadFile();
 
    if(!LoadOK)
    {
        string error("Can't open file ");
        error += temp;
        MessageBox(pinfo->hwnd, error.c_str(), "Error",MB_OK);
        return false;
    }
 
    TiXmlElement *rss = pdata->doc->FirstChildElement("rss");
 
    TiXmlElement *channel = rss->FirstChildElement("channel");
 
    TiXmlElement *item = channel->FirstChildElement("item");
 
    MessageBox(pinfo->hwnd,"Start parsing","",MB_OK);
 
    while(Start < Finish)
    {
        TiXmlElement *title = item->FirstChildElement("title");
 
        wchar_t Temp[1024];
        char AnsiTemp[1024];
 
        MultiByteToWideChar(CP_UTF8,0,title->GetText(),
            -1,Temp,sizeof(Temp));
        WideCharToMultiByte(CP_ACP,0,Temp,-1,AnsiTemp,
            sizeof(AnsiTemp),NULL,NULL);
 
        source[Start].title = new char[strlen(AnsiTemp)+1]; 
        source[Start].title = AnsiTemp;
 
        TiXmlElement *link = item->FirstChildElement("link");
 
        source[Start].link = new char[strlen(link->GetText())+1];
        source[Start].link = const_cast<char *>(link->GetText());
 
        MessageBox(pinfo->hwnd,source[Start].link,"",MB_OK);
 
        Start++;
 
        item = item->NextSiblingElement();
    }
 
    TlsFree(dwTlsIndex);
 
    return true;
}
0
 Аватар для alexey31415
60 / 60 / 7
Регистрация: 16.05.2010
Сообщений: 632
17.07.2012, 01:43  [ТС]
и что?никто не может помочь?
0
Эксперт С++
 Аватар для Avazart
8488 / 6155 / 615
Регистрация: 10.12.2010
Сообщений: 28,683
Записей в блоге: 30
19.07.2012, 23:25
А зачем ждать пока все скачается? А потом только парсить?
Почему сразу и потока закачки не вызывать поток парсинга?
0
 Аватар для alexey31415
60 / 60 / 7
Регистрация: 16.05.2010
Сообщений: 632
20.07.2012, 11:35  [ТС]
всё равно создаётся лишь один файл и завершается лишь один поток
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.07.2012, 11:35
Помогаю со студенческими работами здесь

CreateThread: возможно ли запустить не статический метод класса?
Возможно ли в CreateThread запустить не static процедуру класса? clas_s obj; HANDLE h = CreateThread(0, 0,...

Вернуть значение функции, запущенной через CreateThread
У меня есть некоторая функция, которая через CreateProcess() запускается, но мне нужно как-то получать значение, которая она вычисляет...

Работа с двумерными числовыми массивами. Использование указателей. Использование функций пользователя.
Помогите пожалуйста!!!!!!! Сделать три варианта: первый вариант – передача данных между функциями с помощью глобального...

CreateThread
Как использовать CreateThread в CLR проекте (для метода в классе)? Если просто передавать метод, то cannot convert from...

CreateThread
Есть функция: void one() { while(1) { cout &lt;&lt; &quot;1&quot;; } }


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru