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

Проблемы с кодом Необработанное исключение по адресу 0x00A85A9B - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа с датой и временем http://www.cyberforum.ru/cpp-beginners/thread890072.html
Доброе время суток дорогие программисты, у меня возникла очень большая проблема, которую я не могу решить. Если вам не трудно не могли бы вы помочь. Я, понимаю что правилами нужно присылать код наработки но его попросту нет. Разработать программу для оператора мобильной связи, позволяющую для отдельно введенных значений даты и времени последнего исходящего звонка определить дату и время...
C++ Рекурсией найти файл с самым длинным именем. В чём ошибка? Здравствуйте, программа должна найти файл с самым длинным именем и вывести полностью путь к этому файлу. Ниже код, который после компиляции не выводит ничего, в чём ошибка? #include <cstdlib> #include <iostream> using namespace std; #include <string.h> #include <dirent.h> #include <stdlib.h> http://www.cyberforum.ru/cpp-beginners/thread890068.html
Создать модуль для обработки одномерных массивов с помощью классов C++
Создать модуль для обработки одномерных массивов с помощью классов. Добавлено через 21 час 5 минут Есть у кого какие мысли? =(
C++ Определить операторы как функции члена класса
Добрый вечер! Ребята, помогите решить вот такую задачку: Необходимо определить операторы +, =, +=, -=, *=, , как функции члена класса. И определить функцию печати!
C++ Найти ошибку в программе (считывание из текстового файла трех предложений и их вывод в обратном порядке) http://www.cyberforum.ru/cpp-beginners/thread890038.html
задание было "написать программу которая считывает из текстового файла три предложения и выводит их в обраном порядке " #include <fstream> #include <iostream> #include <cstring> #include <ctype.h> #define LENGTH 20 using namespace std;
C++ Найти наибольший элемент главной диагонали квадратной матрицы Двумерные массивы: 1)Найти наибольший элемент главной диагонали квадратной матрицы A=(ai,k) и вывести на печать всю строку, в которой он находится. (i=k) Спасибо большое. Tuki-Tuki, по правилам форума один вопрос - одна тема. Ваши задания вынесены в отдельные темы: http://www.cyberforum.ru/cpp-beginners/thread890337.html http://www.cyberforum.ru/cpp-beginners/thread890338.html... подробнее

Показать сообщение отдельно
53web
0 / 0 / 0
Регистрация: 04.06.2013
Сообщений: 5

Проблемы с кодом Необработанное исключение по адресу 0x00A85A9B - C++

04.06.2013, 00:50. Просмотров 443. Ответов 3
Метки (Все метки)

Всем доброго времени суток!
Значит есть задание сделать программу: К миниЭВМ подключено четыре терминала, с которых осуществляется решение задач. По команде с терминала выполняют операции редактирования, трансляции, планирования и решения. Причем, если хоть один терминал выполняет планирование, остальные вынуждены простаивать из-за нехватки оперативной памяти. Если два терминала выдают требование на решение, то оставшиеся два простаивают, и если работают три терминала, выдающих задания на трансляцию, то оставшийся терминал блокируется. Интенсивности поступления задач различных типов равны. Задачи одного типа от одного терминала поступают через экспоненциально расположенные интервалы времени со средним значением 160 с. Выполнение одной операции длиться 10 с. Смоделировать работу миниЭВМ в течение 4 ч. Определить загрузку процессора, вероятности простоя терминалов и частоту одновременного выполнения трансляции с трех терминалов.

Пытался сделать программу на C++ вроде все шло гладко, но потом столкнулся с такой проблемой: Необработанное исключение по адресу 0x00A85A9B в Проект6.exe: 0xC0000005: нарушение прав доступа при записи по адресу 0x33C92878.
Может кто поможет разобраться
main.cpp
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
#include "queue.h"
#include <iostream>
#include <stdlib.h>
#include <time.h>
using namespace std;
 
// задаем константы времени в секундах
const int timeWork=4*60*60, timeOfExecute=10, terminalCount=4, taskGenerationTime=160;
 
 
void main()
{
//  srand(time(0));
    int countOfEditors,countOfTranslations;
    bool blockedTerminals[terminalCount], busyTerminals[terminalCount];
    queue terminalTasks[terminalCount];
    int timeCurrent=0, estimatedTime=0, needTime[terminalCount], countOfTranslation=0, countOfEdtitors=0, countOfTranslators=0;
    operationTypes currentOperation[terminalCount];
    
    //инициализация
    for(int k=0; k<terminalCount;k++)
    {
        busyTerminals[k]=false;
        terminalTasks[k].qput(rand()%4);
        needTime[k]=timeOfExecute;
        currentOperation[k]=NONE;
    }
 
    //основной цикл
    while (timeCurrent++<=timeWork)
    {
        for(int k=0; k<terminalCount;k++)
        {
            if (blockedTerminals[k]==false)
            {
                if (busyTerminals[k]==false)
                {
                    currentOperation[k]=terminalTasks[k].qget();
                    switch (currentOperation[k])
                    {
                        case PLAN:
                            for(int i=0; i<terminalCount;i++)
                            {
                                if (i==k)
                                    continue;
                                blockedTerminals[i]=true;
                            }
                            break;
                        case EDIT:
                            countOfEditors++;
                            if (countOfEditors==2)
                            {
                                for(int i=0; i<terminalCount;i++)
                                {
                                    if ((i==k) || (currentOperation[i]==EDIT))
                                        continue;
                                    blockedTerminals[i]=true;
                                }
                            }
                            break;
                        case TRANSLATE:
                            countOfTranslators++;
                            if (countOfTranslators==3)
                            {
                                for(int i=0; i<terminalCount;i++)
                                {
                                    if ((i==k) || (currentOperation[i]==TRANSLATE))continue;
                                    blockedTerminals[i]=true;
                                }
                                countOfTranslations++;
                            }
                            break;
                    }
                    needTime[k]=timeOfExecute;
                }
                //терминал уже занят
                else
                {
                    needTime[k]--;
                    //если задача закончилась
                    if (needTime[k]==0)
                    {
                        busyTerminals[k]=false;
                        if (currentOperation[k]==TRANSLATE)
                        {
                            countOfTranslators--;
                            if (countOfTranslators<3)
                            {
                                for(int i=0; i<terminalCount;i++)
                                {
                                    if ((i==k) || (currentOperation[i]==TRANSLATE))continue;
                                    blockedTerminals[i]=false;
                                }
                            }
 
                        }
                        if (currentOperation[k]==EDIT)
                        {
                            countOfEditors--;
                            if (countOfEditors<2)
                            {
                                for(int i=0; i<terminalCount;i++)
                                {
                                    if ((i==k) || (currentOperation[i]==EDIT))
                                        continue;
                                    blockedTerminals[i]=false;
                                }
                            }
                        }
                        if (currentOperation[k]==PLAN)
                        {
                            for(int i=0; i<terminalCount;i++)
                            {
                                    if (i==k)
                                        continue;
                                    blockedTerminals[i]=false;
                            }
                        }
                        currentOperation[k]=NONE;
                    }
                }
            }
        }
        estimatedTime++;
        if (estimatedTime>=taskGenerationTime)
        {
            for (int k=0; k<terminalCount; k++)
            {
                terminalTasks[k].qput(rand()%4);
            }
            estimatedTime=0;
        }
    }
    cout << "Zagruzka CPU. "<< endl;
    cout << "Prostoi terminalov: "<< endl;
    cout << "Chastota odnovremennogo vypolneniya 3 translaciy: "<< countOfTranslations/timeWork<< endl;
    cin >> estimatedTime;
}
queue.cpp
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
#include "queue.h"
#include <iostream>
using namespace std;
 
void queue::init()
{
    start=0;
    end=0;
}
 
operationTypes queue::qget()
{ 
    if ( start == end )
    {
        cout<<"Queue is empty!";
        return qget();
    }
    cout<<"Element "<<a[end]<<"\n";
    end++;
}
 
bool queue::isEmpty()
{
    if (start==end)
        return true;
    else
        return false;
}
 
operationTypes queue::qput( int m )
{
    if ( 100 == start )
    {
        cout<<"Queue is full!";
         return qget();
    }
        a[start] = m;
    start++;
}
queue.h
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#ifndef QUEUE_H
#define QUEUE_H
 enum operationTypes {EDIT, TRANSLATE, PLAN, SOLVE, NONE};
 
class queue
{ 
public:
    void init();
    operationTypes qput( int m );
  operationTypes qget();
    bool isEmpty();
private:
    int a[100];
    int start,end;
};
#endif
Заранее благодарен, если поможете рад буду отблагодарить бутылкой пива)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru