Инверсия контроля - Inversion of control

В программная инженерия, инверсия контроля (IoC) - принцип программирования. IoC инвертирует поток управления по сравнению с традиционным потоком управления. В IoC специально написанные части компьютерная программа получить поток управления от универсального фреймворк. А программная архитектура с этим дизайном инвертирует управление по сравнению с традиционным процедурное программирование: в традиционном программировании - специальный код, который выражает цель программы. звонки в повторно используемые библиотеки для решения общих задач, но с инверсией управления именно инфраструктура вызывает пользовательский или специфичный для задачи код.

Инверсия управления используется для увеличения модульность программы и сделать это расширяемый,[1] и имеет приложения в объектно-ориентированного программирования и другие парадигмы программирования. Этот термин был использован Майклом Маттссоном в своей диссертации,[2] взято оттуда[3] Стефано Маццокки и популяризировал его в 1999 году в несуществующем проекте Apache Software Foundation, Авалон, а затем популяризировали в 2004 г. Роберт С. Мартин и Мартин Фаулер.

Термин связан с, но отличается от принцип инверсии зависимостей, который касается разъединение зависимостей между высокий и низкий уровень слои через общие абстракции. Общая концепция также связана с событийно-ориентированное программирование в том, что он часто реализуется с использованием IoC, так что пользовательский код обычно занимается только обработкой событий, тогда как цикл событий а отправка событий / сообщений обрабатывается фреймворком или средой выполнения.

Обзор

Например, при традиционном программировании основная функция приложения могут вызывать функции в библиотеке меню для отображения списка доступных команды и попросите пользователя выбрать один.[4] Таким образом, библиотека вернет выбранную опцию как значение вызова функции, а основная функция использует это значение для выполнения связанной команды. Этот стиль был распространен в текстовые интерфейсы. Например, почтовый клиент может отображать экран с командами для загрузки новой почты, ответа на текущее письмо, запуска новой почты и т. д., и выполнение программы будет блокироваться до тех пор, пока пользователь не нажмет клавишу для выбора команды.

С другой стороны, при инверсии управления программа будет написана с использованием программная среда который знает общие поведенческие и графические элементы, такие как оконные системы, меню, управление мышью и т. д. Настраиваемый код «заполняет пробелы» для платформы, такой как предоставление таблицы пунктов меню и регистрация подпрограммы кода для каждого элемента, но это структура, которая отслеживает действия пользователя и вызывает подпрограмму при выборе пункта меню . В примере с почтовым клиентом фреймворк может следить за вводом как с клавиатуры, так и с помощью мыши и вызывать команду, вызванную пользователем любым способом, и в то же время отслеживать сетевой интерфейс чтобы узнать, поступают ли новые сообщения, и обновить экран при обнаружении сетевой активности. Та же самая структура может быть использована в качестве скелета для программы электронных таблиц или текстового редактора. И наоборот, фреймворк ничего не знает о веб-браузерах, электронных таблицах или текстовых редакторах; реализация их функций требует специального кода.

Инверсия управления подразумевает, что повторно используемый код и специфический для проблемы код разрабатываются независимо, даже если они работают вместе в приложении. Обратные вызовы, планировщики, петли событий, внедрение зависимости, а шаблонный метод являются примерами шаблоны проектирования которые следуют принципу инверсии управления, хотя этот термин чаще всего используется в контексте объектно-ориентированного программирования.

Инверсия управления служит следующим целям проектирования:

  • Чтобы разъединять выполнение задачи от реализации.
  • Чтобы сфокусировать модуль на задаче, для которой он предназначен.
  • Освободить модули от предположений о том, как другие системы делают то, что они делают, и вместо этого полагаться на контракты.
  • Предотвращать побочные эффекты при замене модуля.

Инверсию контроля иногда шутливо называют «принципом Голливуда: не звоните нам, мы позвоним вам».

Задний план

Инверсия управления - не новый термин в информатике. Мартин Фаулер прослеживает этимологию фразы до 1988 года,[5] но это тесно связано с концепцией инверсия программы описанный Майкл Джексон в его Структурированное программирование Джексона методология 1970-х гг.[6] А восходящий парсер можно рассматривать как инверсию нисходящий парсер: в одном случае управление лежит на анализаторе, а в другом случае - на принимающем приложении.

Внедрение зависимости это особый тип IoC.[4] А локатор услуг такой как Интерфейс именования и каталогов Java (JNDI) похож. В статье Лука Бергмана,[7] он представлен как архитектурный принцип.

В статье Роберт С. Мартин,[8] принцип инверсии зависимостей и абстракция с помощью слоев объединяются. Его причина использовать термин «инверсия» - это сравнение с традиционными методами разработки программного обеспечения. Когда он говорит об инверсии зависимостей, он описывает разделение сервисов абстракцией слоев. Этот принцип используется, чтобы узнать, где находятся границы системы в дизайне уровней абстракции.

Описание

В традиционном программировании течь из бизнес-логика определяется объектами, которые статически связанный для другого. При инверсии управления поток зависит от графа объектов, который строится во время выполнения программы. Такой динамический поток стал возможным благодаря взаимодействиям объектов, которые определяются через абстракции. Эта привязка во время выполнения достигается такими механизмами, как внедрение зависимости или локатор услуг. В IoC код также может быть связан статически во время компиляции, но поиск кода для выполнения путем чтения его описания из внешняя конфигурация вместо прямой ссылки в самом коде.

При внедрении зависимостей зависимый объект или модуль связан с нужным ему объектом в время выполнения. Какой конкретный объект будет удовлетворять зависимости во время выполнения программы, обычно невозможно узнать в время компиляции с помощью статический анализ. Хотя здесь описывается с точки зрения взаимодействия объектов, этот принцип может применяться к другим методологиям программирования, помимо объектно-ориентированного программирования.

Чтобы запущенная программа могла связывать объекты друг с другом, объекты должны обладать совместимыми интерфейсы. Например, класс А может делегировать поведение интерфейсу я который реализуется классом B; программа создает А и B, а затем вводит B в А.

Методы реализации

В объектно-ориентированного программирования, существует несколько основных методов реализации инверсии управления. Эти:

В оригинальной статье Мартина Фаулера:[9] обсуждаются первые три различных метода. В описании инверсии типов управления,[10] упоминается последний. Часто контекстный поиск выполняется с помощью локатора сервисов.

Примеры

Большинство фреймворков, таких как .СЕТЬ или Корпоративная Java отобразить этот шаблон:

общественный класс СерверФасад {    общественный <K, V> V ответ на запрос(K запрос) {        если (businessLayer.validateRequest(запрос)) {            Данные данные = DAO.получить данные(запрос);            вернуть Аспект.convertData(данные);        }        вернуть значение NULL;    }}

Этот базовый план на Java дает пример кода, следующего за методологией IoC. Однако важно, чтобы в СерверФасад сделано много предположений о данных, возвращаемых объект доступа к данным (ДАО).

Хотя все эти предположения могут быть верны в какой-то момент, они объединяют реализацию СерверФасад к реализации DAO. Разработка приложения способом инверсии управления полностью передаст управление объекту DAO. Тогда код станет

общественный класс СерверФасад {    общественный <K, V> V ответ на запрос(K запрос, DAO дао) {        вернуть дао.получить данные(запрос);    }}

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

Смотрите также

использованная литература

  1. ^ Ральф Э. Джонсон и Брайан Фут (июнь – июль 1988 г.). «Разработка многоразовых классов». Журнал объектно-ориентированного программирования, том 1, номер 2. Департамент компьютерных наук Университета Иллинойса в Урбана-Шампейн. стр. 22–35. Получено 29 апреля 2014.
  2. ^ Майкл Маттссон (февраль 1996 г.). «Объектно-ориентированные рамки. Обзор методологических вопросов».
  3. ^ Стефано Маццокки (22 января 2004 г.). «Об инверсии управления». Архивировано 2 февраля 2004 года.CS1 maint: BOT: статус исходного URL-адреса неизвестен (ссылка на сайт)
  4. ^ а б Внедрение зависимости.
  5. ^ Инверсия контроля на Блики Мартина Фаулера
  6. ^ «Введение в метод проектирования Джексона» (PDF).
  7. ^ Индекс архива на Wayback Machine Внутренняя архитектура: напиши один раз, запусти где угодно, Лук Бергман
  8. ^ Принцип инверсии зависимостей Роберт К. Мартин
  9. ^ Инверсия управляющих контейнеров и шаблон внедрения зависимостей Мартин Фаулер
  10. ^ Типы IoC В архиве 15 июня 2009 г. Wayback Machine

внешние ссылки