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

Архитектура больших программ - C++

Восстановить пароль Регистрация
 
relationer
33 / 0 / 0
Регистрация: 07.11.2013
Сообщений: 118
24.07.2014, 16:57     Архитектура больших программ #1
Здравствуйте!

Пишу довольно большую и комлексную программу. Вопрос - как следует организовывать её внутреннюю структуру? На текущий момент у меня есть дюжина взаимодействующих между собой синглтонов (dataManager, filesManager, userInterfaceManager, inputManager, yetAnotherLongEnglishWordManager, etc), которые обновляет главный цикл.

Однако я слышал много разной критики на паттерн singleton, например, общая удаленность данных между собой, "дальние прыжки процессора по памяти", и т. д.

Вопрос - как внутри делают самый верхний уровень доступа, самый высший уровень абстракции, общую архитектуру в программах с 5000+ строк?
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.07.2014, 16:57     Архитектура больших программ
Посмотрите здесь:

C++ Архитектура ЭВМ на С++
Архитектура размещения h и cpp файлов C++
C++ Архитектура программы. Правильно ли сделал?
Гибкая архитектура и порождающие паттерны C++
C++ Архитектура правильного определения и объявления класса
Объекты и архитектура C++
ОС и архитектура ЭВМ C++
C++ Архитектура программы Доктор
C++ Архитектура компоновки
C++ ООП архитектура игр
C++ Архитектура подписывания на события PhysX
По какому принципу лучше изучать исходники больших программ C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
uglyPinokkio
325 / 228 / 41
Регистрация: 30.05.2014
Сообщений: 682
24.07.2014, 18:48     Архитектура больших программ #2
Дюжина синглетонов скорее всего ошибка в дизайне.


Цитата Сообщение от relationer Посмотреть сообщение
Вопрос - как внутри делают самый верхний уровень доступа, самый высший уровень абстракции, общую архитектуру в программах
http://www.ozon.ru/context/detail/id/2457392/
NeonLost
Пес войны
 Аватар для NeonLost
74 / 85 / 3
Регистрация: 23.02.2012
Сообщений: 653
24.07.2014, 19:01     Архитектура больших программ #3
Цитата Сообщение от uglyPinokkio Посмотреть сообщение
Дюжина синглетонов скорее всего ошибка в дизайне.
полностью согласен...)
почитай что нибуть про MVC, MVVM...)
relationer
33 / 0 / 0
Регистрация: 07.11.2013
Сообщений: 118
24.07.2014, 22:07  [ТС]     Архитектура больших программ #4
Ну, дюжина, это преувеличение, де-факто есть: GraphicsManager, UIManager, InputManager, Timing, и планирую для файлов. Книга - спасибо, хорошая, но я уже читал. Там, я бы сказал, большинство паттернов - для локальных задач. Спасибо за MVC, почитаю. А какие ещё есть способы помимо синглтонов?
NeonLost
Пес войны
 Аватар для NeonLost
74 / 85 / 3
Регистрация: 23.02.2012
Сообщений: 653
24.07.2014, 22:30     Архитектура больших программ #5
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от relationer Посмотреть сообщение
Ну, дюжина, это преувеличение, де-факто есть: GraphicsManager, UIManager, InputManager, Timing, и планирую для файлов. Книга - спасибо, хорошая, но я уже читал. Там, я бы сказал, большинство паттернов - для локальных задач. Спасибо за MVC, почитаю. А какие ещё есть способы помимо синглтонов?
Адаптер (Adapter) - GoF
Декоратор (Decorator) или Оболочка (Wrapper) - GoF
Заместитель (Proxy) или Суррогат (Surrogate) - GoF
Информационный эксперт (Information Expert)- GRASP
Компоновщик (Composite) - GoF
Мост (Bridge), Handle (описатель) или Тело (Body) - GoF
Низкая связанность (Low Coupling) - GRASP
Приспособленец (Flyweight) - GoF
Устойчивый к изменениям (Protected Variations) - GRASP
Фасад (Facade) - GoF
гугли на тему Паттерны проектирования

Добавлено через 9 минут
Цитата Сообщение от NeonLost Посмотреть сообщение
угли на тему Паттерны проектирования
АРХИТЕКТУРНЫЕ СИСТЕМНЫЕ ПАТТЕРНЫ
немного не то написал...)
uglyPinokkio
325 / 228 / 41
Регистрация: 30.05.2014
Сообщений: 682
25.07.2014, 03:46     Архитектура больших программ #6
Цитата Сообщение от relationer Посмотреть сообщение
Там, я бы сказал, большинство паттернов - для локальных задач
Там главное не паттерны, а принципы их применения. 5000 строк - задача вполне "локальная" .
Yandex
Объявления
25.07.2014, 03:46     Архитектура больших программ
Ответ Создать тему
Опции темы

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