Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 04.06.2013
Сообщений: 5

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

04.06.2013, 00:50. Показов 1524. Ответов 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
Заранее благодарен, если поможете рад буду отблагодарить бутылкой пива)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.06.2013, 00:50
Ответы с готовыми решениями:

Необработанное исключение по адресу, нарушение прав доступа при записи по адресу
вот само задание: Авиарейсы (номер рейса, пункт назначения, время вылета, дата вылета, стоимость билета, количество мест). Выбор по дате...

Исправить ошибку: необработанное исключение по адресу, нарушение прав доступа при записи по адресу
Помогите, пожалуйста, исправит ошибку. Необработанное исключение по адресу 0x77D88E19 (ntdll.dll) в Lab11.exe: 0xC0000005: нарушение...

Необработанное исключение по адресу 0x001B3371 в XXX.exe: 0xC0000005: нарушение прав доступа при чтении по адресу 0xFDF
Делал консольную змейку и столкнулся вот с такой проблемой. void stena(char **arr) { int y = 0; int x = 0; ...

3
5499 / 4894 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
04.06.2013, 01:27
Мне компилятор показывает что здесь:
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++
но эта переменная неинициализированна.
0
0 / 0 / 0
Регистрация: 04.06.2013
Сообщений: 5
04.06.2013, 01:28  [ТС]
Ну ошибки в компиляторе я тоже видел, их было больше, просто сейчас уже не думается, думал может кто чего более конкретное подскажет
0
5499 / 4894 / 831
Регистрация: 04.06.2011
Сообщений: 13,587
04.06.2013, 01:52
Цитата Сообщение от 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;
    }
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.06.2013, 01:52
Помогаю со студенческими работами здесь

Необработанное исключение по адресу 0x00ED4891 в strings.exe: 0xC0000005: нарушение прав доступа при чтении по адресу 0xCCCCCCCC
Программа толком не написан, проверял ранд и возникли проблемы. Ф-ция ранд генерирует одно и тоже число, но если убрать srand(time(0));,...

Необработанное исключение по адресу 0x00105FD7 в Динамические структуры: 0xC0000005: нарушение прав доступа при чтении по адресу 0xCDCDCE09
Необработанное исключение по адресу 0x00105FD7 в Динамические структуры.exe: 0xC0000005: нарушение прав доступа при чтении по адресу...

Возникло необработанное исключение по адресу 0x73A62CF2: исключение Microsoft C++: std::bad_array_new_length
Доброго времени суток, уважаемые форумчане :) Подскажите начинающему программисту. Ругается на необработанное исключение по адресу...

Что я сделал не так?Возникло необработанное исключение по адресу 0x7434A9F2 : исключение Microsoft C++: std
//Калькулятор Intrigger #include&lt;iostream&gt; #include&lt;conio.h&gt; #include&lt;string.h&gt; #include&lt;string&gt; #include&lt;cstring&gt; using...

Необработанное исключение по адресу 0x00F71B85 в lab 12_1.exe: 0xC0000005: нарушение прав доступа при чтении по адресу 0
Всем привет, ошибка возникает при добавлении переменной minqq1, помогите понять в чем проблема, вот код: #include &lt;stdio.h&gt; ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru