Форум программистов, компьютерный форум CyberForum.ru

Удаление потоков - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Вычислить суму ряда http://www.cyberforum.ru/cpp-beginners/thread27020.html
Сотворить два типа программ с использованием внешних (глобальных) переменных и переменных, что передаются в функцию и с функции.
C++ Натуральное число, в котором n цифр, если сумма цифр возведённая в nую степень равна числу то вы вывесте число на экран(интервал чисел от 1 до k) Натуральное число, в котором n цифр, если сумма цифр возведённая в nую степень равна числу то вы вывесте число на экран(интервал чисел от 1 до k) http://www.cyberforum.ru/cpp-beginners/thread27014.html
Дан текст. Выяснить или есть он индетификатором. Индетификатор - это последовательность букв и цифр, которые начинаются с буквы. C++
Дан текст. Выяснить или есть он индетификатором. Индетификатор - это последовательность букв и цифр, которые начинаются с буквы. как искать? Добавлено через 11 часов 0 минут 44 секунды как в слове виделить цифру и букву отдельно
сгенерировать квадратную матрицу n*n и сортировать ее в порядке возрастания C++
подскажите кто знает.я уже запарился.язык С надо сгенерировать квадратную матрицу n*n и сортировать ее в порядке возрастания. у меня проблема в том,что цикл отвечающий за сортировку(сортирую прямым перебором)сортирует массив но он заменяет там цифры т.е есть такой набор 8 6 9 5 0 получаю после сортировки 0 5 5 8 9 т.е 6 заменилась на 5 вместо исходной одной 5 и 6 стало две 5.из -за этого...
C++ Армия http://www.cyberforum.ru/cpp-beginners/thread26978.html
Армия (Время: 1 сек. Память: 16 Мб Сложность: 58%) Всем известно, что в армии без строевой подготовки и порядка дело не обходится и за этим там строго следят. Однажды утром сержант построил всех своих подчиненных в K рядов по N человек в каждом, но оказалось, что солдаты выстроились не по росту, и поэтому сержант решил их наказать. Солдаты должны были выстроиться по росту в каждом отдельном...
C++ Найти порядковые номера двух соседних чисел, сумма которых максимальна. 7.79. Дана последовательность целых чисел Х1, Х2,..., Хn где n >= 3. Найти: в) порядковые номера двух соседних чисел, сумма которых максимальна. Если таких пар чисел несколько, то найти номера чисел первой такой пары; 7.116. Даны 20 чисел, образующие неубывающую последовательность. Несколько чисел, идущие подряд, равны между собой. Найти количество таких чисел. Сколько различных чисел имеется... подробнее

Показать сообщение отдельно
Mona
2 / 2 / 0
Регистрация: 15.03.2009
Сообщений: 8

Удаление потоков - C++

22.03.2009, 13:21. Просмотров 1449. Ответов 2
Метки (Все метки)

Программа должна создавать несколько потоков, выводить о них информацию и корректно удалять либо 1 поток, либо все потоки при завершении программы. Вот удаляться потоки вообще не хотят... %) Помогите плз..
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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
#include "conio.h"
#include <windows.h>
#include <strsafe.h>
#include <iostream>
using namespace std;
 
#define MAX_THREADS 3
#define BUF_SIZE 255
int end,j = 4;
int kol = 1;
int flag = 0;
 
typedef struct st {
    int val1;
    int val2;
} MYDATA, *PMYDATA;
 
DWORD WINAPI ThreadProc( LPVOID lpParam ) 
    { 
     HANDLE hStdout;
     PMYDATA pData;
 
        TCHAR msgBuf[BUF_SIZE];
        size_t cchStringSize;
        DWORD dwChars;
    
        hStdout = GetStdHandle(STD_OUTPUT_HANDLE);
        if( hStdout == INVALID_HANDLE_VALUE )
            return 1;
    
     // Cast the parameter to the correct data type.
    
     pData = (PMYDATA)lpParam;
 
        // Print the parameter values using thread-safe functions.
        cout << "Запущен поток " << kol << endl;
        kol++;
        char perem;
        cin >> perem;
        for(int i=0;i<20;i++)
        {
            cout << perem << endl;
            Sleep(3000);
        }
 
        
        // Free the memory allocated by the caller for the thread 
        // data structure.
        HeapFree(GetProcessHeap(), 0, pData);
        
        return 0; 
    } 
 
class CThread
{
public:
    virtual void Execute()
        {
            if(flag==0)
            {
                // Create MAX_THREADS worker threads.
 
            for( i=0; i<MAX_THREADS; i++ )
            {
             // Allocate memory for thread data.
 
                pData =(PMYDATA)HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY,
                sizeof(MYDATA));
 
                if( pData == NULL )
                    ExitProcess(2);
 
                // Generate unique data for each thread.
        
 
                pData->val1 = i;
                pData->val2 = i+100;
        
                hThread[i] = CreateThread( 
                 NULL,              // default security attributes
                    0,                 // use default stack size  
                 &ThreadProc,        // thread function 
                 0,             // argument to thread function 
                 0,                 // use default creation flags 
                 &dwThreadId[i]);   // returns the thread identifier 
 
                // Check the return value for success. 
 
                if (hThread[i] == NULL) 
                {
                    ExitProcess(i);
                }
                flag = 1;
            }
            }
            else
            {
                hThread[j] = CreateThread(NULL,0,&ThreadProc,0,0,&dwThreadId[j]);
                if (hThread[j] == NULL) 
                {
                    ExitProcess(j);
                }
                j++;
            }
    }
    CThread(){}
    ~CThread(){}
    PMYDATA pData;
private:
    DWORD dwThreadId[MAX_THREADS];
    HANDLE hThread[MAX_THREADS];
    int i;
};
    
class CBeepThread: public CThread
{
public:
    void Execute()
    {
        CThread::Execute();
    }
};
 
int main()
{
    int choice;
    char exit = 'N';
    CBeepThread oCBeep;
    setlocale(LC_ALL, "Russian");
    PMYDATA pData;
    DWORD dwThreadId[MAX_THREADS];
    HANDLE hThread[MAX_THREADS];
    int i;
    for(;;)
    {
        cout << "(1)Отображение списка запущенных потоков.\n(2)Создание нового потока.\n";
        cout << "(3)Завершение потока.\n(4)Завершение работы программы.\n" << endl;
        cin >> choice;
        switch (choice)
        {
        case 1: 
            {
                oCBeep.Execute();
                cout << endl;
            }
            break;
        case 2:
            {
                oCBeep.Execute();
                cout << endl;
            }
            break;
        case 3:
            {
                cout << "Введите номер завершаемого потока: " << endl;
                cin >> end;
                WaitForSingleObject(hThread[end],INFINITE);
                TerminateThread(hThread[end],dwThreadId[end]);
            }
            break;
        case 4:
            {               
                cout << "Хотите выйти из программы?\nY/N" << endl;
                cin >> exit;
            }
            break;
        }
        if (exit == 'Y')
        {
            cout << "Завершение работы потоков...\n" << endl;
            WaitForMultipleObjects(MAX_THREADS,hThread,TRUE,INFINITE);
            for(int k=1;k<=MAX_THREADS;k++)
            {
                TerminateThread(hThread[k],dwThreadId[k]);
            }
            break;
        }
            
    }
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru