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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Удаление пробелов http://www.cyberforum.ru/cpp-beginners/thread1059415.html
Помогите пожалуйста доделать программу(удаление пробелов в начале и в конце строки). Само задание:Удаление лишних пробелов в строке (пробелы в начале и в конце строки, а также любые не единичные пробелы между словами). Любые не единичные пробелы между словами программа удаляет, осталось реализовать удаление пробелов в начале и в конце строки. #include <string.h> #include...
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) cin>> *p; http://www.cyberforum.ru/cpp-beginners/thread1059407.html
Не работает C++
Дан вещественный массив vector <float> D5. Занести в массив данные с помощью указателей, определить сумму и количество элементов, вывести на экран полученный массив и адреса элементов #include <iostream> #include <conio.h> #include <math.h> using namespace std; int main() {
C++ Вывести N одинаковых символов
Здравствуйте, уважаемые форумчане. Задачка предельно проста: Вывести пирамиду из символа (например, символа 'X'). Высота пирамиды равна 20 строкам. Должно получиться что-то вроде этого: Я реализовал программу следующим образом: #include <iostream> #include <iomanip>
C++ Программа на файлы http://www.cyberforum.ru/cpp-beginners/thread1059370.html
Здравствуйте,помогите пожалуйста разобраться с программой. Подписать комментарии где какой цикл что делает и что такое end3=false,для чего это нужно.Спасибо! #include <iostream> #include <stdlib.h> #include <stdio.h> #include <string.h> using namespace std; struct zapchasti {
C++ Множество попарно различных плоскостей в трехмерном пространстве задано перечислением троек точек, через которые проходит каждая из плоскостей. Вы* бр В геометрии не силен!!:cry: Множество попарно различных плоскостей в трехмерном пространстве задано перечислением троек точек, через которые проходит каждая из плоскостей. Выбрать максимальное подмножество попарно непараллельных плоскостей. подробнее

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

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

28.12.2013, 15:55. Просмотров 163. Ответов 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;
}
//---------------------------------------------------------------------------
Можете, пожалуйста, объяснить, как она работает?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru