Spring Framework - первые шаги (Конспект седьмой) « Java  «  Статьи  «  Главная страница
Главная страница  |  Статьи  |  Персонал  |  Поток сознания  |  Интересно  |  Киев  |  Карта сайта
 
 
 
Java  |  Project Management  |  Web-development  

Spring Framework - первые шаги (Конспект седьмой)



Яндекс.Погода

12-02-2008 Сегодня мы постараемся разобраться в преимуществах и недостатках, как Constructor Injection (CI), так и Setter Injection (SI).


 
Конспект седьмой : Constructor versus Setter Injection (продолжение)

Сегодня мы постараемся разобраться в преимуществах и недостатках, как Constructor Injection (CI), так и Setter Injection (SI).
Во-первых, следует отметить, что предпочтительно создавать "готовый" объект со всеми инициализациями его полей в одном месте. Поэтому, использование конструктора является прозрачным и более понятным механизмом, т.к. всем разработчикам отлично видно, что и как было инициализированно в момент создания объекта.
Если существует нескольно путей создания объекта, необходимо позаботиться о наличии необходимого количества перегруженных конструкторов.
Вышеописанный метод безусловно хорош, однако при наличии большого количества полей класса (как мне кажется более 5), наличие перегруженных конструкторов может стать ночным кошмаром. Правда, мы не должны забывать и тот факт, что с точки зрения дизайна приложения, класс, содержащий такое количество параметров, вероятнее всего является слишком "тяжелым" и его необходимо подвергнуть рефакторингу - разделить на подклассы, etc. Но все же, в подобном случае, когда количество параметров велико, необходимо переходить к использованию Setter Injection.
С другой стороны, непосредственно сами разработчики Spring Framework, рекомендуют использовать именно Setter Injection, т.к. Constructor Injection может приводить к "ужасному" (messy) коду, и кроме этого Setter Injection позволяет производить переконфигурирование системы во время работы.
Следует так же отметить, что компоненты связанные с session-компонентами, в любом случае должны конфигурироваться исключительно с помощью Setter Injection – почему? Мы ответим на этот вопрос в одной из следующих лекций, когда будем рассматривать диапазоны жизненого цикла компонент (scope).
При использовании Constructor Injection, может возникнуть еще одна проблема, известная как Кольцевая Зависимость (Circular dependencies)

Представьте себе ситуацию, когда конструктор класса А требует в качестве параметра экземпляр класса B, а тот в свою очередь требует в констуркторе наличие класса A!? В этом случае, Spring Framework, не сможет "поднять" экземпляры упомянутых компонент (beans), и выбросит исключительную ситуацию: BeanCurrentlyInCreationException

Выходом из подобной ситуации будет переход к Setter Injection. В этом случае при создании объектов, поля будут проинициализиорованы null и только в следующем проходе Spring выполнит Setter Injection.
Таким образом, не существует жестких требований, заставляющих разработчиков использовать тот или иной метод. Более того, современные фреймворки, как правило поддерживают как SI, так и CI. Не является исключением в этом плане и Spring Framework. Пользуйтесь здравым смыслом и приобретенным опытом  .




Комментарии к статье "Spring Framework - первые шаги (Конспект седьмой)" (1)

Andrew: 07-10-2008 17-28
Отличные статьи для новичков в ЕЕ.. Хочется продолжений


Вам есть, что сказать?




  Введите код

1
Веб Приложение на ОСГИ 04-08-2008
Технология OSGi позволяет создавать модульные приложения, которое легко может конфигурироваться путем добавления,удаления или обновления модулей. В данном примеры мы рассмотрим создания простейшего веб-приложения как часть (модуль) другого приложения, основанного на OSGi
2
Spring Framework - первые шаги (Конспект десятый) 05-03-2008
Напомню задачу, с которой может столкнуться любой Java Developer: "В качестве контроллера в нашей подсистеме будет выступать ShoppingCartShowController, поднятый в контексте приложения как singleton. А в качестве модели, будет выступать компонента ShoppingCart, поднятая в контексте сессии".
3
Spring Framework 2.5.2 Released 04-03-2008
Вышел второй апдейт для Spring 2.5, он содержит исправление ошибок найденных в версии 2.5.1 и представляет целый ряд улучшений во фреймворке.
4
Spring Framework - первые шаги (Конспект девятый) 26-02-2008
Теперь давайте усложним ситуацию и представим себе, что первая компонента описана как singleton, а вторая, как prototype. Кроме этого принимаем во внимание, что «singleton» агрегирует в себе «prototype». Что будет происходить в этом случае?
5
Spring Framework - первые шаги (Конспект восьмой : Beans scope) 19-02-2008
Как я и обещал в одной из предыдущих лекций, пришло время поговорить про диапазоны видимости компонент (beans scope).
6
Spring Framework - первые шаги (Конспект седьмой) 12-02-2008
Сегодня мы постараемся разобраться в преимуществах и недостатках, как Constructor Injection (CI), так и Setter Injection (SI).
7
Spring Framework - первые шаги (Конспект шестой) 05-02-2008
Использование Constructor и Setter Injection в Spring Framework
8
Spring Framework - первые шаги (Конспект пятый) 29-01-2008
Существует несколько способов „поднятия“ application context. Для иллюстрации я остановлюсь на простейшем способе, который с успехом можно использовать при разработке юнит тестов.
9
Спрос на Spring разработчиков неуклонно растет 25-01-2008
Спрос на Spring разработчиков неуклонно растет, отмечает в своем блоге Род Джонсон.
10
Spring Framework - первые шаги (Конспект четвертый) 22-01-2008
Теперь, прежде чем перейти к экспериментам с фреймворком, нам осталось разобраться, собственно, каким образом Spring связывает компоненты между собой.
11
Январская конференция JUG Украина :: Кластеры на основе Terracotta 19-01-2008
Последнее собрание украинского JUG прошло в достаточно шикарной обстановке отеля Hyatt Regency. Лично меня презентация, привезенная Джонасом Бонером, посвященная построению кластеров на основе Open Source продукта, разрабатываемого его компанией, Terracotta, очень порадовала.
12
Spring Framework - первые шаги (Конспект третий) 14-01-2008
Прежде чем двигаться дальше и рассматривать следующие немаловажные аспекты Spring Framework, я позволю себе остановиться на мнениях относительно DI (IoC) различных авторитетных разработчиков.
13
Spring Framework – первые шаги (Конспект второй) 08-01-2008
Во время этой лекции нам предстоит разобраться с фундаментальным принципом, положенным в основу работы Spring Framework – Inversion of Control (Ioc). И надо признаться, что это не простая задача, т.к. единства мнения в целесообразности использования этого принципа нет. В начале нам предстоит понять, кто кого инвертирует и кто кого контроллирует.
14
Spring Framework – первые шаги (Конспект первый) 04-01-2008
Spring Framework – явление на Олимпе индустрии разработки программного обеспечения, достойное внимания, хотя бы потому, что Spring смог выйти за рамки Java сообщества и сделать шаг в „святая святых“ - в .Net. Используя опыт, приобретенный мною во время преподавания на тренингах по подготовке Java разработчиков, я постарюсь в цикле статей донести до читателей нашего сайта основные концепции, заложенные в Spring. Создать „конспект лекций“, который поможет Вам сделать свои первые шаги в мир J2EE с использованием Spring Framework.
15
RSS Injection (Часть 2) 31-12-2007
Ни для кого не секрет, что в последнее время RSS каналы стали не только популярным средством продвижения новостных лент, но и эффективным способом обмена информационными потоками между сайтами. В данной статье речь пойдет о том, как реализовать потребность в RSS, используя один из самых популярных фреймворков – Spring.
1
2
»


 
 
 
©2007 Lifein
Использовать материалы www.lifein.com.ua можно, лишь для Интернет-изданий установив гиперссылку на www.lifein.com.ua. Иначе, нарушители будут привлечены к ответственности, согласно Закона Украины "Про авторське право і суміжні права" от 23 декабря 1993 года № 3792-ХІІ статьи 50-53.