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

Нужно написать генерацию исключений для методов, как это делается?

24.06.2015, 17:22. Показов 670. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
вот все задание , но нужно лишь последний абзац

Задание:
Разработать абстрактный класс TList, отвечающий за хранение целочисленных элементов внутри массива, а также классы TStack и TQueue – потомки класса TList, обеспечивающие работу соответственно со стеком и очередью.
Класс TList отвечает за создание и уничтожение массива целых чисел, содержит сведения о рабочем и физическом размере массива, и предоставляет интерфейс для доступа к элементам массива. Кроме того, TList содержит два виртуальных метода без реализации:
void Put(int x) – записать число x в массив
int Get() – прочитать число из массива
От класса TList наследуются два класса: TStack и TQueue.
Класс TStack предназначен для работы со стеком, построенным на основе массива. Класса TStack переопределяет виртуальные методы класса TList:
Put – записать число в стек (добавить число в конец массива)
Get – извлечь число из стека (прочитать и удалить последнее записанное число)
Класс TQueue предназначен для работы с очередью, построенной на основе массива. Класса TQueue переопределяет виртуальные методы класса TList:
Put – записать число в очередь (добавить число в конец массива)
Get – извлечь число из очереди (прочитать и удалить первое число из массива)

Предусмотреть для методов Get в классах TStack и TQueue генерацию исключительных ситуаций в случае невозможности прочитать элементы из стека или из очереди. Предусмотреть для методов Put в классах TStack и TQueue генерацию исключительных ситуаций в случае невозможности записать элементы в стек или в очередь из-за переполнения массива.

сама программа
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
#include <iostream>
#include <conio.h>
#include <math.h>
using namespace std;
class TList{
public:
int i;
int A[500];
bool addMass();
int deleteMass();
char infMass();
void Put();
int Get();
TList();};
bool TList::addMass()
{cout<<"TList::addMass:"<<endl;
    cout<<"Заполните массив:\n";
for(int k=1; k<=i; k++)
    cin>>A[k];
return true;}
TList::TList()
{i=4;}
int TList::deleteMass()
{cout<<"deleteMass:"<<endl;
    cout<<"Удаление массива... ";
const int n=500;    
bool deleteMass();
if(i>=n)
{cout<<" Ошибка!"<<endl;
return false;}
else
{for(int q=1; q<i-1;q++)
{A[q]=A[q+1];}
cout<<" успешно!"<<endl;
return true;}};
char TList::infMass()
{cout<<"informations about massive:"<<endl;
    cout<<"Информация о видах памяти массива:"<<endl;
const int n=500;
cout<<"Динамический размер массива:"<<n<<endl;
cout<<"Статический размер массива:"<<i<<endl;
return true;};
void TList::Put()
{cout<<"Put:"<<endl;
    cout<<"Добавление числа в массив:"<<endl;
const int n=500;
int x;
cout<<"Введите новый элемент:"<<endl;
cin>>x;
A[i+1]=x;
cout<<"A["<<i+1<<"]: "<<A[i+1]<<endl;
i++;};
int TList::Get()
{cout<<"Get:"<<endl;
    int a=0;
cout<<"Выберите номер элемента из массива:";
cin>>a;
for(int k=0; k<a+1; k++)
{if(k=a)
{cout<<"A["<<k<<"]: "<<A[k]<<endl;
 
return a;}
else
    return a;}};
class TStack: public TList{
public:
virtual int Put()
{cout<<"TStack:"<<endl;
cout<<"Put:"<<endl;
    const int n=500;
int x;
cout<<"Enter new element:";
cin>>x;
A[i+1]=x;
cout<<"A["<<i+1<<"]:"<<A[i+1]<<endl;
i++;
return true;}
virtual int Get()
{cout<<"Get:"<<endl;
    int x;
cout<<"Enter number element deleted:"<<endl;
cin>>x;
for(int k=0; k<i; k++)
    if(k=x)
{cout<<"A["<<k<<"]:"<<A[k]<<endl;
~A[k];
return true;}
    else
        cout<<"false"<<endl;
return false;};
TStack();};
TStack::TStack()
{cout<<"Enter element's massive for TStack:"<<endl;
    for(int k=1; k<i+1; k++)
cin>>A[k];};
class TQueue: public TList{
public:
virtual int Get()
{int x;
cout<<"Enter new element:";
cin>>x;
A[i+1]=x;
cout<<"A["<<i+1<<"]="<<A[i+1]<<endl;
return false;}
virtual int Put()
{cout<<"Первый элемент:"<<endl;
    cout<<"A[1]:"<<A[1]<<endl;
    cout<<"Удаление числа..."<<endl;
for (int q=1; q<4; q++)
{A[q]=A[q+1];}
cout<<"delete true!"<<endl;
return true;}
TQueue();};
TQueue::TQueue()
{cout<<"Enter element's massive for TQueue:"<<endl;
    for(int k=1; k<i+1; k++)
cin>>A[k];};
void main()
{setlocale(LC_ALL,"Russian");
TList l;
TStack k;
TQueue q;
l.addMass();
l.Get();
l.infMass();
l.Put();
l.deleteMass();
k.Put();
k.Get();
q.Put();
q.Get();
system("pause");}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.06.2015, 17:22
Ответы с готовыми решениями:

Связанный список. Как это делается и зачем это нужно?
Добрый день. Уже который день не могу понять эту тему. Гуглил, но понятнее от этого не стало. Кто-нибудь знает где найти понятный мануал?

Нужно ли удалять EventListener? Если да как правильно это делается?
Здравствуйте нужно ли удалять обработчики событий EventListener? Если да то подскажите как логически правильно это делать? Например...

Один из методов шифрации называется наложением гаммы. Делается это следующим образом: берется некоторое случайное число
Один из методов шифрации называется наложением гаммы. Делается это следующим образом: берется некоторое случайное число в диапазоне от 127...

1
Эксперт С++
 Аватар для hoggy
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
24.06.2015, 17:36
Цитата Сообщение от validolik Посмотреть сообщение
Предусмотреть для методов Get в классах TStack и TQueue генерацию исключительных ситуаций в случае невозможности прочитать элементы из стека или из очереди.
C++
1
2
if( !read_data() )
    throw std::logic_error("не могу прочитать данные");
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.06.2015, 17:36
Помогаю со студенческими работами здесь

Как на vb.net делается обработка исключений try catch?
как на vb.net делается обработка исключений try catch ? например System.ArgumentException Добавлено через 3 минуты на C# было бы...

Нужно написать логическое выражение для расчета суммы выплаты по депозиту. Как это делать?
Задание: Написать логическое выражение для расчета суммы выплаты по депозиту на вклад : до 5000 грн начисляется 20% годовых, от 5000 грн до...

Как это делается?
Необходимо поставить специалисту задачу, но для этого необходимо понять, что за специалист требуется. Пример того, что нужно сделать здесь:...

Как это делается
Даётся задача, её надо решить на каком нибудь языке программирования, то есть написать на этом языке программу, решающую данную задачу, а...

Как это делается?
Сколько существует натуральных чисел, для которых одновременно выполняются следующие условия: 1.Запись числа в семеричной системе...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru