Форум программистов, компьютерный форум, киберфорум
Наши страницы

синхронизации задач с несколькими потоками выполнения - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Удаление пробелов http://www.cyberforum.ru/cpp-beginners/thread1059415.html
Помогите пожалуйста доделать программу(удаление пробелов в начале и в конце строки). Само задание:Удаление лишних пробелов в строке (пробелы в начале и в конце строки, а также любые не...
C++ Блок-схема #include <iostream> #include <conio.h> using namespace std; void main() { const size_t SIZE = 10; float* vector = new float; float *p; for(p = vector ; p<vector+SIZE; ++p) ... http://www.cyberforum.ru/cpp-beginners/thread1059407.html
Не работает C++
Дан вещественный массив vector <float> D5. Занести в массив данные с помощью указателей, определить сумму и количество элементов, вывести на экран полученный массив и адреса элементов #include...
C++ Вывести N одинаковых символов
Здравствуйте, уважаемые форумчане. Задачка предельно проста: Вывести пирамиду из символа (например, символа 'X'). Высота пирамиды равна 20 строкам. Должно получиться что-то вроде этого: Я...
C++ Программа на файлы http://www.cyberforum.ru/cpp-beginners/thread1059370.html
Здравствуйте,помогите пожалуйста разобраться с программой. Подписать комментарии где какой цикл что делает и что такое end3=false,для чего это нужно.Спасибо! #include <iostream> #include...
C++ Множество попарно различных плоскостей в трехмерном пространстве задано перечислением троек точек, через которые проходит каждая из плоскостей. Вы* бр В геометрии не силен!!:cry: Множество попарно различных плоскостей в трехмерном пространстве задано перечислением троек точек, через которые проходит каждая из плоскостей. Выбрать максимальное... подробнее

Показать сообщение отдельно
malishev
9 / 9 / 0
Регистрация: 17.12.2012
Сообщений: 123

синхронизации задач с несколькими потоками выполнения - C++

28.12.2013, 15:55. Просмотров 172. Ответов 0
Метки (Все метки)

Здравствуйте. Мне нужна ваша помощь.
Есть задача:
Реализовать моделирование «тупика» на примере работы с критическими секциями. Временные параметры модели определяются до начала моделирования (произвольны, но обязательно изменяемы). Провести анализ вероятности тупика, если она равна 1, то обосновать.

Вот код программы
C++ (Qt)
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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#include <conio.h>
#include <stdio.h>
#include <iostream>
#include <windows.h>
#include <winbase.h>
#include <winnt.h>
#include <stdlib.h>
#include <string.h>
#include <tchar.h>
#include <process.h>
#include <queue>
#include <time.h>
#pragma hdrstop
 
//---------------------------------------------------------------------------
//структура масива
struct mass
{
  bool Z;
  int mass[100];
};
// 2 масива
mass m1;
mass m2;
//процедуры потока  1
DWORD WINAPI POTOK1 (LPVOID param)
//void POTOK1(void* params)
{
   printf("POtok1 \n");
   while(true)
   {
   while(m1.Z)
   {
      printf("O1 m1 ");
      Sleep(100);
   };
   printf("/n");
   m1.Z=true;
   m2.Z=true;
   for (int i=0;i<100;i++)
   {
     m1.mass[i]=1;
   };
   //m1.Z=false;
   while(m2.Z)
   {
      printf("O1 m2 ");
      Sleep(100);
   };
   printf("/n");
   //m2.Z=true;
   for (int i=0;i<100;i++)
   {
     m2.mass[i]=1;
   };
   m1.Z=false;
   m2.Z=false;
   }
   //return 0;
};
//процедуры потока  2
DWORD WINAPI POTOK2 (LPVOID param)
//void POTOK2(void* params)
{
   printf("POtok2 \n");
   //Sleep(100);
   while(true)
   {
   while(m2.Z)
   {
       printf("O2 m2 ");
       Sleep(100);
   };
   printf("/n");
   m2.Z=true;
   m1.Z=true;
   for (int i=0;i<100;i++)
   {
     m2.mass[i]=2;
   };
   //m2.Z=false;
   while(m1.Z)
   {
       printf("O2 m1 ");
       Sleep(100);
   };
   printf("/n");
   //m1.Z=true;
   for (int i=0;i<100;i++)
   {
     m1.mass[i]=2;
   };
   m2.Z=false;
   m1.Z=false;
   }
   //return 0;
};
#pragma argsused
int main(int argc, char* argv[])
{
        m1.Z=false;
        m2.Z=false;
       // _beginthread(POTOK1, 0, (void*) NULL);
       // _beginthread(POTOK2, 0, (void*) NULL);
        HANDLE p1;
        HANDLE p2;
 
 
        p1=CreateThread(0,0,POTOK1,NULL,CREATE_SUSPENDED,NULL);
        p2=CreateThread(0,0,POTOK2,NULL,CREATE_SUSPENDED,NULL);
        ResumeThread(p1);
        ResumeThread(p2);
        while(true)
        {
        Sleep(999);
        printf("[ \n");
        printf("MAasiv 1 \n");
        for (int i=0;i<100;i++)
        {
                 printf("%d",m1.mass[i]);
 
        };
        printf("\n");
        printf("MAasiv 2 \n");
        for (int i=0;i<100;i++)
        {
                 printf("%d",m2.mass[i]);
 
        };
        printf("\n");
        printf("] \n");
        }
        system("PAUSE");
        return 0;
}
//---------------------------------------------------------------------------
Можете, пожалуйста, объяснить, как она работает?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.