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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
53web
0 / 0 / 0
Регистрация: 04.06.2013
Сообщений: 5
#1

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

04.06.2013, 00:50. Просмотров 477. Ответов 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
Заранее благодарен, если поможете рад буду отблагодарить бутылкой пива)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
04.06.2013, 00:50     Проблемы с кодом Необработанное исключение по адресу 0x00A85A9B
Посмотрите здесь:

Необработанное исключение по адресу - C++
Необработанное исключение по адресу...нарушение прав доступа при чтении по адресу... #include &lt;iostream&gt; #include &lt;conio.h&gt; #include...

Необработанное исключение по адресу - C++
Описать процедуру SortInc(A,N), выполняющую сортировку по возрастанию массива А из N вещественных чисел. Массив А является входным и...

Необработанное исключение по адресу - C++
Доброго времени суток!!!!:) ест программа в ней переменная которой присваивается ссылка после чего программа немного ее корректирует и...

Необработанное исключение по адресу - C++
Доброго времени суток! Долгое время учился кодить на Паскале, в данный момент появилось желание начать кодить на С. В общем хотел...

Необработанное исключение по адресу 0x002F1637 - C++
Доброго времени суток. В процессе написания программы для лабораторной работы я столкнулся с кое-каким препятствием. Собственно, код: ...

Ошибка: необработанное исключение по адресу - C++
Из за чего может вылезти такая ошибка? #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;ctime&gt; #include &lt;cstdlib&gt; #include...

Необработанное исключение по адресу 0x009F6F05 - C++
#include&lt;iostream&gt; #include&lt;string.h&gt; #include&lt;stdio.h&gt; #include&lt;windows.h&gt; #include&lt;conio.h&gt; using namespace std; struct NOTE ...

Работа с классом. Необработанное исключение по адресу - C++
В общем. Есть класс матрицы, я реализую сложение двух матриц. Когда я пишу так: Matrix C = A + B; Все прекрасно работает. А когда...

Необработанное исключение по адресу при выводе на консоль - C++
Доброго времени суток. #include &lt;iostream&gt; #include &lt;string&gt; using namespace std; class YearData { public: int day; ...

Необработанное исключение по адресу при вводе даты - C++
имеется код #include &lt;stdio.h&gt; #include &lt;iostream&gt; #include &lt;conio.h&gt; using namespace std; int main() ...

Нахождение определителя матрицы по Гауссу, ошибка - необработанное исключение по адресу - C++
Помогите, пожалуйста, написал алгоритм нахождения определителя ступенчатой матрицы, мб неправильно передаю двумерный массив в функцию? ...

Необработанное исключение по адресу (msvcp110d.dll): нарушение прав досупа при записи - C++
Доброго времени суток. Надеюсь на вашу помощь в решении моей проблемы. Я имею две функции, первая считывает и перезаписывает в бинарном...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alsav22
5416 / 4812 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
04.06.2013, 01:27     Проблемы с кодом Необработанное исключение по адресу 0x00A85A9B #2
Мне компилятор показывает что здесь:
C++
1
2
3
4
5
6
7
8
9
10
operationTypes queue::qget()
{ 
    if ( start == end )
    {
        cout<<"Queue is empty!";
        return qget();
    }
    cout<<"Element "<<a[end]<<"\n";
    end++;
}
и здесь:
C++
1
2
3
4
5
6
7
8
9
10
operationTypes queue::qput( int m )
{
    if ( 100 == start )
    {
        cout<<"Queue is full!";
         return qget();
    }
        a[start] = m; // здесь возникает исключение
    start++;
}
значение возвращается не при всех путях выполнения.
В 70 строке, в main():
C++
1
countOfTranslations++
но эта переменная неинициализированна.
53web
0 / 0 / 0
Регистрация: 04.06.2013
Сообщений: 5
04.06.2013, 01:28  [ТС]     Проблемы с кодом Необработанное исключение по адресу 0x00A85A9B #3
Ну ошибки в компиляторе я тоже видел, их было больше, просто сейчас уже не думается, думал может кто чего более конкретное подскажет
alsav22
5416 / 4812 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
04.06.2013, 01:52     Проблемы с кодом Необработанное исключение по адресу 0x00A85A9B #4
Цитата Сообщение от 53web Посмотреть сообщение
может кто чего более конкретное подскажет
Чтобы не было проблем, нужно возвраты нормальные сделать. А конкретнее, когда у вас код доходит до этой функции:
C++
1
2
3
4
5
6
7
8
9
10
operationTypes queue::qput( int m )
{
    if ( 100 == start )
    {
        cout<<"Queue is full!";
         return qget();
    }
    a[start] = m;
    start++;
}
в start находится мусор. Потом в массив, по этому "мусорному индексу", делается попытка записи, отчего и исключение.

Добавлено через 16 минут
Цитата Сообщение от 53web Посмотреть сообщение
Ну ошибки в компиляторе я тоже видел
А исправить? Ждёте следующих исключений?
Если инициализацию так сделать, то это исключение исчезнет:
C++
1
2
3
4
5
6
7
8
9
//инициализация
    for(int k=0; k<terminalCount;k++)
    {
        busyTerminals[k]=false;
        terminalTasks[k].init(); // добавлено
        terminalTasks[k].qput(rand()%4);
        needTime[k]=timeOfExecute;
        currentOperation[k]=NONE;
    }
Yandex
Объявления
04.06.2013, 01:52     Проблемы с кодом Необработанное исключение по адресу 0x00A85A9B
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru