Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.03.19;
Скачать: CL | DM;

Вниз

Структура программы   Найти похожие ветки 

 
RayGun ©   (2006-02-17 21:30) [0]

Здравствуйте, уважаемые Мастера!

Согласно современным требованиям при создании более-менее крупного проекта рекомендуется придерживаться разделения структуры классов программы на графический интерфейс (GUI), бизнес-логику, уровень доступа к данным (DAL) и, при необходимости, железный уровень (HAL).
Так вот, вопрос: где провести границу между бизнес-логикой и DAL? Не противоречит ли этой идеологии обращение из GUI  непосредственно к TDataSet и его потомкам, расположенными в DataModule, или же следует использовать для этого дополнительную прослойку в виде классов бизнес-логики с методами типа GetXXX, CreateXXX и UpdateXXX (я не имею в виду формы, содержащие TDBGrid и его аналоги типа UltraGrid и т.п., для них уже как бы есть прослойка)?
Какую посоветуете литературу по правильному проектированию структуры программы?


 
API   (2006-02-17 21:37) [1]

Это смотря насколько абстрагироваться.
Для кого и TDataSet - служба данных.

Какую посоветуете литературу по правильному проектированию структуры программы?

Брандт Д., Architectures. Exam 70-100.- СПб.: Питер, 2001.- 432 с.: ил.

Но лучше - поработать пару лет в группе.
А то можно такого напроектировать...


 
Игорь Шевченко ©   (2006-02-17 21:41) [2]


> Не противоречит ли этой идеологии обращение из GUI  непосредственно
> к TDataSet и его потомкам, расположенными в DataModule


Вообще-то противоречит, но писать полный аналог data-aware controls для разрешения этого противоречия является, на мой взгляд, довольно неблагодарным занятием, так как немалый объяем работы будет потрачен на повторение уже сделанного.


> Какую посоветуете литературу по правильному проектированию
> структуры программы?


Мартин Фаулер, Архитектура корпоративных приложений, но для Delphi оттуда можно взять только часть.

В электронном виде часть материалов выложена на сайте автора
http://www.martinfowler.com на английском языке.


> (я не имею в виду формы, содержащие TDBGrid и его аналоги
> типа UltraGrid и т.п., для них уже как бы есть прослойка)


Для них тоже нет прослойки, потому что такие формы обращаются к Dataset, минуя методы объекта бизнес-логики, отсюда получается, что единой точки доступа к данным с учетом бизнес-правил не существует. кроме того, такие формы работают с данными, а не с объектами, что в общем-то тоже противоречит чистой теории.

Пример альтернативной разработки data-aware controls можно найти в
http://www.techinsite.com.au/tiOPF/Download.htm
(Object Persistent Framework)

С наилучшими,


 
RayGun ©   (2006-02-17 21:50) [3]

Большое спасибо!

В группе работал, но не на Delphi/CPP Builder, а на Visual Studio .Net (C#), там у нас использовался ADO.NET, а теперь возникла задача использовать Delphi или Builder. Вот в связи с этим и приходится разбираться с правильным построением структуры программы на Delphi/Cpp Builder, чтобы не создавать проги, написанные на ButtonClick.


 
Desdechado ©   (2006-02-17 22:41) [4]

<off>
одни бегут с дельфи на C# из-за продажи борландом, а другие мигрируют в обратном направлении
мда....
</off>



Страницы: 1 вся ветка

Текущий архив: 2006.03.19;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.049 c
2-1141627235
WChek
2006-03-06 09:40
2006.03.19
отлов события


15-1140903519
DillerXX
2006-02-26 00:38
2006.03.19
Посмотрите что я творил ;)


1-1139580437
EvilDream
2006-02-10 17:07
2006.03.19
Быстрый поиск ближайшего соседа


11-1121184395
Dodfr
2005-07-12 20:06
2006.03.19
How to workaround missing TComponent ? with FindObj ?


2-1141166680
MotorManayk
2006-03-01 01:44
2006.03.19
Работа с WinAPI