Russian Qt Forum
Ноябрь 05, 2024, 22:07
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Вопросы новичков
>
Помогите с архитектурой приложения
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Помогите с архитектурой приложения (Прочитано 4818 раз)
Edynchik
Гость
Помогите с архитектурой приложения
«
:
Июль 17, 2013, 16:31 »
Добрый день! Возникла следующая проблема, экспериментальным путем доказано что моя архитектура не работает. Предложите, пожалуйста, альтернативу. В общем зада следующая. Есть канал из которого необходимо считывать информацию, и отображать на экране. Я ее решил следующим образом, создал класс формы,в нем еще два класса. Один для считывания из канала (отдельный класс, потому что каналов несколько) и класс отображения (графиков отображения может быть тоже несколько). Когда по таймеру из канала считалась информация посылается сигнал в форму у которого параметром выставлена необходимая для записи инфа. Класс отображения по таймеру выдает сигнал в форму - запрос информации. И форма соответственно обработав этот сигнал, передает сигнал содержащий данные для отображения. И все вроде отлично работало до момента работы деструктора: возникает ситуация в которой сигнал с запросом инфы для отображения уже послан,срабатывает деструктор класса отображения и соответсвенно рисовать уже некуда...как следствие крах. Что можно придумать?
Записан
Bepec
Гость
Re: Помогите с архитектурой приложения
«
Ответ #1 :
Июль 17, 2013, 16:39 »
Это ваша тема про осциллографы? Что-то такое там было
Переусложнённая у вас архитектура.
Моё видение:
1) класс главного окна приложения.
2) класс отображения графика.
3) класс приёма информации (мб даже в отдельном потоке
).
Архитектура проста - 2)/3) существуют связками. Точнее 2) в конструкторе создаёт привязанный к себе 3).
3) получает информацию, отсылая сигналом данные в 2). 2) получает данные и отображает их.
При закрытии 2) сначала уничтожается 3) и после чего удаляется 2).
PS ох блин понаписал я
самому бы потом понять.
Записан
Edynchik
Гость
Re: Помогите с архитектурой приложения
«
Ответ #2 :
Июль 17, 2013, 16:45 »
Цитата: Bepec от Июль 17, 2013, 16:39
Это ваша тема про осциллографы? Что-то такое там было
Переусложнённая у вас архитектура.
Моё видение:
1) класс главного окна приложения.
2) класс отображения графика.
3) класс приёма информации (мб даже в отдельном потоке
).
Архитектура проста - 2)/3) существуют связками. Точнее 2) в конструкторе создаёт привязанный к себе 3).
3) получает информацию, отсылая сигналом данные в 2). 2) получает данные и отображает их.
При закрытии 2) сначала уничтожается 3) и после чего удаляется 2).
PS ох блин понаписал я
самому бы потом понять.
да все таже тема...пытался как то реанимировать, но бестолку...в ваших словах определенно есть логика...хм а есть еще тонкие моменты в будущем о которых можете предупредить...
Записан
kambala
Джедай : наставник для всех
Offline
Сообщений: 4746
Re: Помогите с архитектурой приложения
«
Ответ #3 :
Июль 17, 2013, 17:50 »
Цитата: Edynchik от Июль 17, 2013, 16:31
И все вроде отлично работало до момента работы деструктора: возникает ситуация в которой сигнал с запросом инфы для отображения уже послан,срабатывает деструктор класса отображения и соответсвенно рисовать уже некуда...как следствие крах. Что можно придумать?
можно добавить класс-менеджер, который будет перенаправлять сигналы в объект отображения если он существует
Записан
Изучением C++ вымощена дорога в Qt.
UTF-8 has been around since 1993 and Unicode 2.0 since 1996; if you have created any 8-bit character content since 1996 in anything other than UTF-8, then I hate you. © Matt Gallagher
Bepec
Гость
Re: Помогите с архитектурой приложения
«
Ответ #4 :
Июль 17, 2013, 22:05 »
Я думаю, что вашу программу можно реанимировать спокойно и неспешно. Но увы, нужно это смотреть на работающем проекте
Записан
Edynchik
Гость
Re: Помогите с архитектурой приложения
«
Ответ #5 :
Июль 18, 2013, 12:53 »
Цитата: Bepec от Июль 17, 2013, 16:39
Это ваша тема про осциллографы? Что-то такое там было
Переусложнённая у вас архитектура.
Моё видение:
1) класс главного окна приложения.
2) класс отображения графика.
3) класс приёма информации (мб даже в отдельном потоке
).
Архитектура проста - 2)/3) существуют связками. Точнее 2) в конструкторе создаёт привязанный к себе 3).
3) получает информацию, отсылая сигналом данные в 2). 2) получает данные и отображает их.
При закрытии 2) сначала уничтожается 3) и после чего удаляется 2).
PS ох блин понаписал я
самому бы потом понять.
изначально у меня так и было сделано, только пришлось от нее отказаться ввиду того, что информация из одного канала может понадобится нескольким классам отображения...т.е. я сделал сохранение данных из канала в классе формы...
«
Последнее редактирование: Июль 18, 2013, 12:58 от Edynchik
»
Записан
Bepec
Гость
Re: Помогите с архитектурой приложения
«
Ответ #6 :
Июль 18, 2013, 15:47 »
Ничто не мешает посылать второй сигнал допустим.
Но лучше тогда менеджера создавать.
Записан
Old
Джедай : наставник для всех
Online
Сообщений: 4350
Re: Помогите с архитектурой приложения
«
Ответ #7 :
Июль 18, 2013, 15:50 »
Цитата: Bepec от Июль 18, 2013, 15:47
Ничто не мешает посылать второй сигнал допустим.
Но лучше тогда менеджера создавать.
Зачем? К одному сигналу могут быть привязаны стопитсот получателей.
Записан
Bepec
Гость
Re: Помогите с архитектурой приложения
«
Ответ #8 :
Июль 18, 2013, 19:27 »
Потому что менеджер - это хорошо. А 100500 связанных сигналов - это плохо для отладки.
Записан
Old
Джедай : наставник для всех
Online
Сообщений: 4350
Re: Помогите с архитектурой приложения
«
Ответ #9 :
Июль 18, 2013, 19:51 »
Аргументы будут?
Записан
Edynchik
Гость
Re: Помогите с архитектурой приложения
«
Ответ #10 :
Июль 18, 2013, 20:00 »
Цитата: Bepec от Июль 18, 2013, 15:47
Ничто не мешает посылать второй сигнал допустим.
Но лучше тогда менеджера создавать.
Не могли бы описать работу класса менеджера? То что управлять, понятно...а далее...
Записан
Old
Джедай : наставник для всех
Online
Сообщений: 4350
Re: Помогите с архитектурой приложения
«
Ответ #11 :
Июль 18, 2013, 20:17 »
Цитата: Edynchik от Июль 18, 2013, 20:00
Не могли бы описать работу класса менеджера? То что управлять, понятно...а далее...
Хороший вопрос.
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...