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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.70
DiMasKiss
1 / 1 / 0
Регистрация: 12.12.2009
Сообщений: 30
#1

Из ООП - динамическая структура через агрегацию - C++

23.04.2010, 17:14. Просмотров 1172. Ответов 4
Метки нет (Все метки)

Всем привет! Помогите реализовать динамическую структуру через агрегацию.

есть абстрактный класс
C++
1
2
3
4
5
6
7
class iXml
{
    public:
 
    virtual AnsiString TypePrint()=0;
 
};
и есть четыре типа объекта из которых и состоит динамическая структура
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
class State: public iXml
{
    public:
    AnsiString Type;
    State(AnsiString str);
    SetState(iXml &N);
    virtual AnsiString TypePrint();
};
 
class Join: public iXml
{
    public:
    AnsiString Type;
    Join(AnsiString str);
    virtual AnsiString TypePrint();
};
 
class Fork: public iXml
{
    public:
    AnsiString Type;
    Fork(AnsiString str);
    virtual AnsiString TypePrint();
};
подскажите, пожалуйста, как можно реализовать динамическую структуру применяя принцип агрегации - связать объекты между собой, причем динамически.
пытался через vector объектов не получается;
пытался применить патерн компоновщик, тоже не выходит.
В общем помогите разобраться?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.04.2010, 17:14
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Из ООП - динамическая структура через агрегацию (C++):

Динамическая матрица ООП - C++
Добрый день, проблема заключается в следующем. Никак не могу разобраться с заданием Задание: Для хранения объектов каждого...

Динамическая память в ООП - C++
Здравствуйте, программа должна находить площадь и определять равносторонний ли треугольник. Площадь ищется только в случае равенства трех...

Динамическая структура - C++
Добрый день. Хочу создать примерно такую структуру: struct person { char name, char delimeter, char age, char delimeter, ... ...

Динамическая структура - C++
Составить программу, которая содержит динамическую информацию о наличии автобусов в автобусном парке. Сведения о каждом автобусе...

Динамическая структура - C++
Помогите пожалуйста с заданием. Дано задание: На междугородной телефонной станции картотека абонентов, содержащая сведения о телефонах и...

Динамическая структура очередь - C++
Ребят,можете помочь. Создать очередь на базе связного списка. Написать функцию, выводящую на экран n (вводится с клавиатуры) элементов с...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Roma_F
331 / 246 / 5
Регистрация: 13.12.2009
Сообщений: 589
23.04.2010, 18:22 #2
Цитата Сообщение от DiMasKiss Посмотреть сообщение
пытался через vector объектов не получается;
пытался применить патерн компоновщик, тоже не выходит.
а можно текст попыток? что именно не получается?

Цитата Сообщение от DiMasKiss Посмотреть сообщение
есть четыре типа объекта
точно четыре?
DiMasKiss
1 / 1 / 0
Регистрация: 12.12.2009
Сообщений: 30
24.04.2010, 12:47  [ТС] #3
Проблема в следующем:
Раз структура динамическая, то должен быть массив узлов - vector, но как присвоить этому массиву 4 вида объектов из разных экземпляров класса. Массив vector при объявлении его в качестве экземпляра абстрактного класса (интерфейса) выдает ошибку.
С паттерном мне не понятно как он работает, если там структура создается рекуррентно (без массива) при создании следующего узла внутри объекта, то помойму при рекуррентном выходе срабатывает деструктор объектов, и даже если объекты сохраняются, то в частном порядке к ним не обратишься.
Roma_F
331 / 246 / 5
Регистрация: 13.12.2009
Сообщений: 589
24.04.2010, 14:09 #4
Цитата Сообщение от DiMasKiss Посмотреть сообщение
Массив vector при объявлении его в качестве экземпляра абстрактного класса (интерфейса) выдает ошибку.
И почему у каждого нужно клещами информацию вытаскивать..
Повторюсь: где текст попыток и какая ошибка?

вот пример использования
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
    std::vector<iXml *> items;
    State *item1 = new State("1");
    Join *item2 = new Join("2");
    Fork *item3 = new Fork("3");
 
    items.push_back (item1);
    items.push_back (item2);
    items.push_back (item3);
 
    for (int i=0; i<3; i++)
    {
        items.at(i)->TypePrint();
    }
то помойму при рекуррентном выходе срабатывает деструктор объектов, и даже если объекты сохраняются, то в частном порядке к ним не обратишься
если объёкты создаются через new, ничего никуда не пропадёт
DiMasKiss
1 / 1 / 0
Регистрация: 12.12.2009
Сообщений: 30
25.04.2010, 20:05  [ТС] #5
Спасибо большое) работает
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.04.2010, 20:05
Привет! Вот еще темы с ответами:

Динамическая структура данных в С++ - C++
Определить функции вставки нового звена в односвязный линейный список, удаления звена из списка, просмотра содержимого списка. как вот...

Динамическая структура данных - C++
Дано type строка=array of char; дата=record число:1..31; месяц:1..12; год:1900..1979 end;анкета=record фамилия:строка;пол:(муж,...

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

Динамическая структура данных - C++
Нужна помощь с динамическими структурами данных: Написать программу, которая сохраняет элементы с помощью динамической структуры...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
25.04.2010, 20:05
Ответ Создать тему
Опции темы

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