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

Эмуляция планировщика процессов с использованием волокон. Алгоритм "случайный выбор" - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Классы http://www.cyberforum.ru/cpp-beginners/thread441968.html
Дан класс почтовая сортировка.Нужно реализовать функции вычисления суммарного количества посылок(amount) и суммарную ценность(price).Перезагрузить операции "<",">","==" для сравнения двух объектов класса по суммарному количеству посылок. Подскажите пожалуйста, хоть с чего начать.Давно не работала с классами.Заранее спасибо! #include <cstdlib> #include <iostream> using namespace std; class...
C++ C++ простейшая программа Пару дней, как начал учить с++ и вот как бы первая проблема: #include "std_lib_facilities.h" int main() { setlocale(LC_CTYPE,"RUS"); cout << "Пожалуйста, введите ваше имя (на англ.) (затем нажмите 'Enter')\n"; string first_name="???"; http://www.cyberforum.ru/cpp-beginners/thread441953.html
C++ выбрать из string числа
Подскажите плс как из string равной допустим "123ghj42" вытащить числа и засунуть их в int переменную? что то вроде: int main() { string str; cin>>str; int i=0; while(str!='\0')
C++ Оптимизация условия цикла while
Доброго времени суток, друзья! Я еще совсем новичок в С++. Подскажите плз как оптимизировать следующее условие выхода из цикла while. Уж очень громоздко выглядит, и что-то внутри меня подсказывает что это можно как-то сократить:) char ch = 'a'; while (ch != 42 && ch != 43 && ch != 45 && ch != 47)
C++ Поменять местами столбы в массиве http://www.cyberforum.ru/cpp-beginners/thread441927.html
Вот есть программа.Нужно поменять местами столбец где есть максимальный элемент с первым столбцом.И значение элементам массива задать случайное. #include <iostream.h> #include <conio.h> #include <stdio.h> #include <windows.h> int main () {
C++ Как правильно вставить переменную? Вот программа: #include <iostream> #include <cstdlib> #include <fstream> #include <stdio.h> #include <string> #include <io.h> #include <windows.h> #include <cmath> подробнее

Показать сообщение отдельно
DIEUDEVIL
Сообщений: n/a
07.02.2012, 18:00     Эмуляция планировщика процессов с использованием волокон. Алгоритм "случайный выбор"
Прошу помочь.Есть готовая программа(готовый код).Хочу знать, что значит каждая строка кода. Для написания курсовой работы.
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
using namespace std;
 
char bufRus[256];
 
char* Rus(const char* text)
{
      CharToOem(text, bufRus);
      return bufRus;
}
static LPVOID  fiberEnd;
static LPVOID  fiberCtl;
static LPVOID  fiber[ FIBERS ];
static void shedule( BOOL fDontEnd )
{
  int     n, current;
  if ( !fDontEnd ) {  /* волокно надо завершить */
    fiberEnd = GetCurrentFiber();
    SwitchToFiber(fiberCtl ); 
  }
  /* выбираем следующее волокно для выполнения */
  for ( n = 0; n < FIBERS; n++ ) {
    if ( fiber[n] && fiber[n] != GetCurrentFiber() ) break;
  }
  if ( n >= FIBERS ) return;  /* нет других готовых волокон*/
SwitchToFiber( fiber[rand()%3] );
}
VOID CALLBACK Proc( PVOID lpParameter, int id  )
{  
  int  i;
  for ( i = 0; i < 100; i++ ) {
    cout <<Rus("Волокно ")<<id<<endl;  
    Sleep( 1000 );
    shedule( TRUE );  /* выполнение продолжается */
  }
  shedule( FALSE ); /* волокно завершается */
}
VOID CALLBACK FiberProc( PVOID lpParameter )
{  
  Proc(lpParameter,1);
}
VOID CALLBACK FiberProc2( PVOID lpParameter )
{  
     Proc(lpParameter,2);
}
VOID CALLBACK FiberProc3( PVOID lpParameter )
{  
     Proc(lpParameter,3);
}
int main()
{
  int  i;
  fiberCtl = ConvertThreadToFiber( NULL );
  fiberEnd = NULL;
    fiber[0] = CreateFiber( 10000, FiberProc, NULL );
    fiber[1] = CreateFiber( 10000, FiberProc2, NULL );
    fiber[2] = CreateFiber( 10000, FiberProc3, NULL );
    for ( i = 0; i < FIBERS;) {
    SwitchToFiber( fiber[rand()%FIBERS] );
    if ( fiberEnd ) {
      DeleteFiber(fiberEnd );
      for ( i = 0; i < FIBERS; i++ ) {
        if ( fiber[i] == fiberEnd ) fiber[i] = NULL;
      }
      fiberEnd = NULL;
    }
    for ( i = 0; i < FIBERS; i++ ) if ( fiber[i] ) break;
  }
  ConvertFiberToThread();
  return 0;
}
Добавлено через 19 часов 45 минут
Помогите, пожалуйста......Разве здесь нет человека знающего.....
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 18:49. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru