:
есть класс A в котом мы работаем с бд(добавляем, считываем данные)
есть метод ReadAndDisplay - он считывает данные с таблицы и показывает их
и когда я писал этот метод, я подумал, а классу A надо знать о том как именно показывать данные? на консоль, или может в винформ выведу, он же это знать не должен?
и вот я создаю делегат DisplayDatabase, создаю метод для подписки нового метода в обработчик делегата RegisterDelegate и при считывании инфы с таблицы вызываю его
а в классе Program я подписываю обработчик делегата, с выводом на консоль и вызываю метод ReadAndDisplay
С точки зрения 'архитектуры' все логично, но было бы правильнее полностью отвязать данные от функций их получения и показа
ты хочешь постранично их загружать и много раз вызывать этот метод?
та нет, просто когда писал, подумал, может разумнее было бы вот заюзать делегат, тк можно будет потом подвязывать туда разные реализации дисплея бд
Возвращай просто данные
Для вин формы не нужно создавать делегат, там свой есть EventHandler как то так, от него ивент создаешь в классе и подписываешь делегат с обработкой
Обсуждают сегодня