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

Синхронизация потоков - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Если массив является перестановкой, т.е. содержит все числа от 1 до N, то вывести 0 http://www.cyberforum.ru/cpp-beginners/thread524333.html
Array49. Дан целочисленный массив размера N. Если он является перестановкой, т. е. содержит все числа от 1 до N, то вывести 0; в противном случае вывести номер первого недопустимого элемента. Вот решение на Паскале. Program Array49; const n=10; var arr:arrayof integer; tem:arrayof integer;
C++ Число(денежное) в строку с реализацией милиардов собственно надо чтобы число перекидывалось в например строку такого типа: семь триллионов сто восемнадцать миллиардов двести десять миллионов пятьсот тридцать две тысячи шестьсот девять рублей и 43 копейки у меня есть код до миллиарда.. может у кого-нт есть и дальше? или хотя бы до триллиона http://www.cyberforum.ru/cpp-beginners/thread524325.html
C++ Поменять поиск информации по класу (си++)
Доброй ночи, помогите пожалуйста сделать кое-какие изменения в програмке, буду благодарен) Нужно изменить как-то по другому поиск по заданным критериям, и ещё можно одновременно задавать два-три критерия в поиске? А не один как, сделал я) Цель задачи: Создать класс компьютер, и на его основе описать компьютерную аудиторию. Осуществить поиск по заданным(любым) параметрам, которые описаны в...
C++ задача
Доброго времени суток. Нужна помощь. сегодня столкнулась с такой задачей (ранее была похожая задача).. Создать класс, содержащий данные, а также методы ввода, вывода и выборки по условию. Данные: название диска, фамилия исполнителя, название песни, время звучания. Вывести сведения о дисках данного исполнителя, указав их общее количество. Проблема у меня возникла с выборкой, поскольку тип...
C++ Найти среднее арифметическое всех целых чисел на промежутке http://www.cyberforum.ru/cpp-beginners/thread524305.html
найти среднее арифметическое всех целых чисел на промежутке которые диляьться на 5 и 7
C++ класс "Таймер" [C++] Требуется написать программу, реализующую класс "Таймер". Таймер должен иметь два интерфейсных метода: метод для установки начального значения и метод для печати текущего значения. Минимальное начальное значение -1 с., максимальное 23ч.59м.59с. Использование умалчиваемых параметров функций приветствуется. Функционал отсчета времени в таймере можно не реализовывать. Для реализации функционала... подробнее

Показать сообщение отдельно
МихаилМ
26 / 26 / 1
Регистрация: 11.11.2009
Сообщений: 86
22.03.2012, 13:08     Синхронизация потоков
Нужно синхронизовать потоки с помощью event
Как правильно сделать.

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
#include <stdlib.h>
#include <stdio.h>
#include <windows.h>
#include <conio.h>
#include <tchar.h>
#include <iostream>
#include <locale.h>
using namespace std;
 
struct Queue {
        char * data;
        Queue *next;
} ;
 
Queue * _begin=NULL;
 HANDLE hEvent;
 
 
DWORD WINAPI MyThread (LPVOID &lpParam)
{
hEvent = CreateEvent (NULL, TRUE, FALSE, "MyEvent");
 
        char*y="my.txt";
        HANDLE hFile;
        DWORD k;
        char *data;
        int size;
        data = (char *) malloc (20 * sizeof (char));
        
        Queue* que=(Queue*) lpParam;
 
        hFile = CreateFile (y, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
        
        Queue *tmp=NULL;
        
        while(true){
                if(que)
                        while (que ->next) que=que->next;
WaitForSingleObject (hEvent, INFINITE);
 
                if(tmp!=que){
                memcpy (data, que->data, 20);
                tmp=que;
                size = strlen(que->data);
                WriteFile (hFile, &size, sizeof (size), &k, NULL);
                WriteFile (hFile, que->data, size, &k, NULL); 
 
                //que = que->next;
                }
        }        
        
        CloseHandle (hFile);
                //ExitThread (0);
        return 0;
} 
 
void Put(Queue**, char*);
void PrintQueue(Queue*);
 
 
int main()
{
        HANDLE hThread; 
        HANDLE hFile;
        DWORD ThID;
        DWORD k;
        char *y;
        char* data;
        setlocale(LC_ALL,"russian");
        
 
        //Create thread
        hThread = CreateThread (NULL, 0,(LPTHREAD_START_ROUTINE)MyThread, &_begin, 0, &ThID);
        if (hThread == NULL){printf ("Ошибка. Нельзя создать поток!\n");}
                SuspendThread(hThread);
 
        int yy=0;
 
        do{
                printf("1.Добавить элемент в стек и записать в файл\n");
                printf("2.PrintQueue\n");
        
        switch(yy)
                {
                        
        case 1:
                y= new char[20];
                y[0] = '\0';
                printf("Введите элемент:");
                scanf("%s",y);
                
                Put(&_begin,y);
                                  SetEvent (hEvent);
            ResetEvent (hEvent);
 
                printf("Элемент записан в файл\n");
                
                
                        break;
        case 2:
                PrintQueue(_begin);
        }       
        }while(cin>>yy);
                return 0;
        }
 
 
 
void Put(Queue** queue, char* data)// поместить данные в конец очереди
{
Queue* que1 = (Queue*)calloc(1,sizeof(Queue));
que1->data=(char*)malloc(strlen(data)+1);
     
que1->data=data;
Queue* tmp=*queue;
        if(!tmp)
        *queue=que1;
    else
    {
                while(tmp->next) tmp=tmp->next;
                tmp->next=que1;
    }
}
 
 
void PrintQueue(Queue*queue) { // вывод на экран содержимого очереди
        printf("\n");
                while(queue){
                        
                        printf(queue->data);
                        printf("\n");
            queue = queue->next;
                }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 01:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru