Научная статья на тему 'Аспектно-ориентированное программирование в контексте решения вопросов повышения эффективности экономических показателей IT-проектов'

Аспектно-ориентированное программирование в контексте решения вопросов повышения эффективности экономических показателей IT-проектов Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
373
95
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
аспектно-ориентированное программирование / задача / информационная система / проектирование / программирование / эффективность / aspect-oriented programming / AOP / task / information system / engineering / programming / efficiency

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — А А. Гончаров, Н А. Семенов

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

i Надоели баннеры? Вы всегда можете отключить рекламу.
iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

ASPECT-ORIENTED PROGRAMMING AS AN APPROACH TO IMPROVE THE EFFICIENCY OF IT PROJECTS ECONOMIC PERFORMANCE

Budget evaluation of the developed project, expenditure classification, time development planning and cost analysis are accompanied by inaccuracies and distortions due to the fact that the initial code of industrial information systems is characterized by undue complexity, excessive duplication, formulaic errors, uncertainty, strong relationships between mod-ules. The article is devoted to the method of solving the current problem of increasing efficiency of IT-projects economic per-formance. It describes the modern approach to large-scale information system design using aspect-oriented programming. Aspect-oriented programming is a modern development of object-oriented programming. It is intended to separate business logic from information systems through features. Business logic describes business rules implementation for particular indus-trial enterprises. The article highlights the relevance of using aspect-oriented programming in large industrial information systems. It also describes its advantages and disadvantages in terms of the greatest practical value. The authors propose a mechanism that allows abstracting business processes at all stages of design iterations and implementation of non-essential (auxiliary) aspects of the system. In addition, the article provides a practical example of using aspect-oriented programming. Abstracting a set of problems into aspects allows obtaining the correct display of the links between business processes and requirements to the implementation of the designed information system domain objects.

Текст научной работы на тему «Аспектно-ориентированное программирование в контексте решения вопросов повышения эффективности экономических показателей IT-проектов»

УДК 004.413.5 Дата подачи статьи: 05.04.16

DOI: 10.15827/0236-235X.115.149-153

АСПЕКТНО-ОРИЕНТИРОВАННОЕ ПРОГРАММИРОВАНИЕ В КОНТЕКСТЕ РЕШЕНИЯ ВОПРОСОВ ПОВЫШЕНИЯ ЭФФЕКТИВНОСТИ ЭКОНОМИЧЕСКИХ ПОКАЗАТЕЛЕЙ 1Т-ПРОЕКТОВ

А.А. Гончаров, аспирант, andre_goncharov@hotmailcom; Н.А. Семенов, д.т.н., профессор, [email protected] (Тверской государственный технический университет, наб. Аф. Никитина, 22, г. Тверь, 170026, Россия)

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

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

Аспектно-ориентированное программирование является современным развитием объектно-ориентированного программирования и предназначено для отделения бизнес-логики информационных систем от сквозных функций. Бизнес-логика описывает реализацию бизнес-правил для конкретного промышленного предприятия.

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

Кроме этого, в статье приводится практический пример использования аспектно-ориентированного программирования.

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

Ключевые слова: аспектно-ориентированное программирование, задача, информационная система, проектирование, программирование, эффективность.

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

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

Таким образом, необходим механизм, позволяющий абстрагировать каждый бизнес-процесс предприятия на всех итерациях стадий проектирования и реализации ПО от несущественных (вспомогательных) аспектов системы.

Методологии программирования

Среди основных методологий программирования (императивного, функционального, логического программирования и объектно-ориентированного программирования (ООП)) наиболее востребованным подходом при проектировании и

разработке ПО является ООП (Object-Oriented Programming) [1].

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

ООП можно описать четырьмя главными характерными свойствами: абстрагирование, инкапсуляция, модульность, иерархия (рис. 1).

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

Инкапсуляция предназначена для сокрытия реализации элементов, описывающих поведение объекта.

Под модульностью подразумевается свойство разделения программы на независимые составные части - модули.

Иерархия позволяет упорядочить абстракции и модули, формируя из них уровни взаимодействия.

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

В связи с этим особую актуальность приобретает применение инновационного подхода к проектированию ПО, который с точки зрения разработки ПО позволит

- значительно повысить уровень программной абстракции;

- разрабатывать ПО как независимую совокупность различных надежных компонентов функциональности и предметной области;

- повысить качество исходного кода: уменьшить дублирование и, как следствие, объем, повысить прозрачность (улучшить структуру) и читаемость, упростить тестирование;

- не зависеть от возможного изменения конфигурации ИС (масштабирование);

- систематически добавлять и модифицировать функциональность (адаптивность);

- упростить разработку документации и сопровождение ИС.

С точки зрения экономических показателей позволит

- повысить точность оценки предполагаемого бюджета разрабатываемой ИС;

- улучшить качество решений при планировании сроков разработки ИС;

- рациональнее распределять расходы по аспектам разработки ИС;

- корректно отражать величину трудозатрат при разработке ИС на каждом из этапов жизненного цикла ПО.

Парадигмой программирования, нацеленной на решение указанных проблем, является аспектно-ориентированное программирование (АОП).

Описание АОП

АОП является современным развитием ООП и предназначено для отделения бизнес-логики ИС от сквозных функций.

Сквозная функциональность (Cross-cutting concern) - это функциональность, рассеянная по всему исходному коду ПО, систематически независимая от предметной области. АОП предоставляет возможность вызывать код сквозных функций без изменения исходного кода программы в определенный момент работы программы [4]:

- перед вызовом метода;

- после вызова метода независимо от результата;

- после успешного вызова (выполнение метода завершилось успешно);

- после исключения (вызванный метод возбудил исключение);

- вокруг (до и после вызова метода).

К общесистемным требованиям обычно относятся сквозные функции (рис. 2).

К сокращению количества вариантов сквозной функциональности приводит реализация главной цели АОП, которая состоит в том, что типовой код (не связанный с решением прикладных задач предметной области и повторяющийся от компонента к компоненту) не должен смешиваться с прикладной бизнес-логикой [4].

Описание предлагаемой модели ПО

Наиболее общую модель архитектуры промышленной ИС без использования АОП можно представить множеством ИСМ = {СПО, ^Б}, где ИСМ -

v сф сф j

обозначение модели промышленной ИС; СПО -сведения о предметной области; £ Б - набор реализаций функций бизнес-логики ИС; СФ - сквозная функциональность.

Сведения о предметной области представляют собой формализованную структуру, отображающую взаимодействие бизнес-процессов предприятия.

Под бизнес-логикой понимается набор функций, необходимый для корректного и полного описания алгоритма взаимодействия бизнес-процессов предприятия на каком-либо языке программирования.

Общая модель архитектуры промышленной ИС без использования АОП в соответствии с представленным множеством отражена на рисунке 3.

В данном подходе целевой код будущей ИС зависит от общесистемных требований (сквозной функциональности). Это приводит к увеличению сложности модификации кода и невозможности повторного использования кода, реализующего конкретную, специфичную для данной предметной области поведенческую особенность ИС.

Рис. 2. Сквозная функциональность в промышленных ИС Fig. 2. Cross-cutting concern in industrial information .systems

Модель ПО с использованием АОП можно транслитерировать в следующее представление: ИСмаоп = {СПО,£Б,СФ}, где ИСМдоп - обозначение модели промышленной ИС с использованием АОП; СПО - сведения о предметной области; ЕБ -набор реализаций функций бизнес-логики ИС; СФ - сквозная функциональность.

Общая модель архитектуры промышленной ИС с использованием АОП представлена на рисунке 4.

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

Иллюстрация использования АОП

В качестве иллюстрации использования АОП рассмотрим следующий фрагмент программы на языке Java:

public class UserFileService {

public void getCustomInfo(File file) {

if (file == null) {

throw new FileNotFoundException(

file.getPath() + " not found..."); }

if (this.id == file.id) {

System.out.println(file.getInfo()); }

else {

throw new SecurityException(

"Not allowed"); }

} }

Данный модуль (метод getCustomlnfo объекта класса UserFileService) реализует алгоритмы двух аспектов:

- вывод на экран титульных сведений о содержимом объекта класса File - главный аспект;

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

Поскольку к одному модулю программы предъявляются требования сразу двух аспектов, один из которых реализует сквозную функциональность, средствами АОП необходимо изолировать данные аспекты в независимые модули (для примера был выбран язык Aspect!, который является расширением языка Java):

public class UserFileService {

public void getCustomInfo(File file) {

System.out.println(file.getInfo()); }

}

public aspect Security {

void around(UserFileService service,

File file): call(void

UserFileService.getCustomInfo(File))

&& args(file) && target(service) {

if (file == null) {

throw new FileNotFoundException(

file.getPath() + " not found..."); }

if (file.id == service.id) {

proceed(service, file); }

else {

throw new SecurityException(

"Not allowed"); }

} }

Общая модель крупной промышленной ИС без использования АОП

ИС

Сведения о предметной области —|.

Сквозная функциональность

Функция

Функция

Функция

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

Сквозная функциональность

Общая модель крупной промышленной ИС с использованием АОП

ИС

Сведения о предметной области

Функция

Функция

Функция

Сквозная функциональность

Рис. 4. Общая модель ИС с использованием АОП

Fig. 4. A general model of an information system with AOP

Как видно, реализация чтения титульных сведений о содержимом объекта класса File теперь изолирована от сквозной функциональности (проверки совпадения значений идентификаторов файлов, доступных для чтения текущему пользователю).

Параметр aspect предназначен для инициализации нового аспекта - Security.

С помощью конструкции around объявляется, что вместо метода UserFileService.getCustom-Info(File) будет выполнен метод (алгоритм), указанный в фигурных скобках [5]. Алгоритм реализует сквозную функциональность (простую проверку совпадения идентификаторов файлов).

Служебное слово proceed выполняет метод getCustomlnfo объекта service класса UserFileService с аргументом file класса File в случае успеха выполнения алгоритма сквозной функциональности [6].

Преимущества и недостатки методологии

АОП с точки зрения наибольшей практической ценности приведены в таблице.

В целом можно отметить, что основная польза АОП заключается в повышении прозрачности кода

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

Преимущества и недостатки АОП

AOP advantages and disadvantages

Преимущество Недостаток

Более прозрачный код логики (уменьшение связанности классов) Отсутствие структурированной информации о разработке ПО с использованием данной методологии

Легкость модификации кода Высокий порог вхождения (трудности с пониманием концепции)

Меньшая вероятность возникновения ошибок Ограниченная помощь среды разработки (IDE)

Соблюдение принципа DRY (Don't repeat you're self - не повторяйся) [7] Отсутствие подробной документации на русском языке

Уменьшение шаблонных ошибок Незначительное снижение скорости выполнения кода

Упрощение разработки документации, и, как следствие, улучшение ее читаемости

Улучшение модульности ИС (модули содержат только базовую функциональность, а вторичные проблемы вынесены в аспекты)

Упрощение модульного тестирования (unit testing)

Недостатки в контексте использования методологии АОП при разработке крупных промышленных ИС не являются существенными.

В заключение сделаем следующие выводы. Реализация сквозной функциональности в отдельные автономные модули, называемые аспектами, является существенным отличием АОП от иных парадигм разработки ПО.

Аспектно-ориентированный сценарий жизненного цикла программного продукта, с одной стороны, предполагает упрощение адаптации к каждому конкретному 1Т-проекту, с другой, поднимает качество оценки эффективности экономических показателей на новый уровень.

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

- оценка предполагаемого бюджета разрабатываемой ИС без фактического проектирования;

- варьирование численностью команды разработчиков при наличии эквивалентной работы;

Бизнес-логика

Бизнес-логика

- гибкое распределение сроков разработки и соблюдение требуемого качества программного продукта независимо от количества функциональных точек [8];

- уменьшение трудности поиска разумного компромисса между функционалом и затратами ресурсов на создание ИС;

- прозрачность понимания в каждый конкретный момент времени реальной продуктивности разработчиков.

Абстрагирование и модуляризация совокупности задач в аспекты позволяет получить корректное отображение связей между бизнес-процессами и требованиями к реализации объектов предметной области проектируемой ИС.

Независимость целевого кода и аспектов способствует реализации более гибкого процесса разработки ПО, тем самым предполагается улучшение качества принимаемых экономических решений на всех итерациях жизненного цикла программного продукта.

Литература

1. Programming Community Index - TIOBE Index. URL: http://www.tiobe.com/tiobe_index?page=index (дата обращения: 28.02.2016).

2. Блинов И.Н., Романчик В.С. Java. Методы программирования. Минск: Четыре четверти, 2013. 896 с.

3. Стелтинг С., Маасен О. Применение шаблонов Java. Библиотека профессионала. М.: Вильямс, 2002. 576 с.

4. Йенер М., Фидом А. Java EE. Паттерны проектирования для профессионалов. СПб: Питер, 2016. С. 122-123.

5. Laddad R., Johnson R. AspectJ in Action: Enterprise AOP with Spring Applications, Manning Publ., 2009. 568 p.

6. Gradecki J.D., Lesiecki N. Mastering AspectJ: Aspect-Oriented Programming in Java, Wiley Publ., 2003. 456 p.

7. The Don't Repeat Yourself Principle and the Wormhole Anti-Pattern. URL: http://codebetter.com/jeremymiller/2007/03/22/ the-dont-repeat-yourself-principle-and-the-wormhole-anti-pattern/ (дата обращения: 28.02.2016).

8. Уоллс К. Spring в действии. М.: ДМК Пресс, 2013. С. 202-203.

9. Буч Г. Объектно-ориентированный анализ и проектирование. М.: Вильямс, 2010. С. 506-509.

10. Репин В.В., Елиферов В.Г. Процессный подход к управлению. Моделирование бизнес-процессов. М.: Манн, Иванов и Фербер, 2013. 544 с.

DOI: 10.15827/0236-235X.115.149-153 Received 05.04.16

ASPECT-ORIENTED PROGRAMMING AS AN APPROACH TO IMPROVE THE EFFICIENCY OF IT PROJECTS ECONOMIC PERFORMANCE

1Goncharov A.A., Postgraduate Student, [email protected]

lSemenovN.A., Dr.Sc. (Engineering), Professor, [email protected]

lTver State Technical University, Nikitin Quay 22, Tver, 170026, Russian Federation

Abstract. Budget evaluation of the developed project, expenditure classification, time development planning and cost analysis are accompanied by inaccuracies and distortions due to the fact that the initial code of industrial information systems is characterized by undue complexity, excessive duplication, formulaic errors, uncertainty, strong relationships between modules.

The article is devoted to the method of solving the current problem of increasing efficiency of IT-projects economic performance. It describes the modern approach to large-scale information system design using aspect-oriented programming.

Aspect-oriented programming is a modern development of object-oriented programming. It is intended to separate business logic from information systems through features. Business logic describes business rules implementation for particular industrial enterprises.

The article highlights the relevance of using aspect-oriented programming in large industrial information systems. It also describes its advantages and disadvantages in terms of the greatest practical value. The authors propose a mechanism that allows abstracting business processes at all stages of design iterations and implementation of non-essential (auxiliary) aspects of the system.

In addition, the article provides a practical example of using aspect-oriented programming.

Abstracting a set of problems into aspects allows obtaining the correct display of the links between business processes and requirements to the implementation of the designed information system domain objects.

Keywords: aspect-oriented programming, AOP, task, information system, engineering, programming, efficiency.

References

1. Programming Community Index - TIOBE Index. Available at: http://www.tiobe.com/tiobe_index7pageHndex (accessed February 28, 2016).

2. Blinov I.N., Romanchik V.S. Java. Metodyprogrammirovaniya [Java. Programming Methods]. Minsk, Chetyre Chetverti Publ., 2013, 896 p.

3. Stelting S., Maassen O. Applied Java Patterns. Prentice Hall Publ., 2002, 608 p. (Russ.ed.: Moscow, Williams Publ., 2002, 576 p.).

4. Yener M., Theedom A. Professional Java EE Design Patterns. Wrox Publ., 2015, 264 p. (Russ.ed.: St. Petersburg, Piter Publ., 2016, pp. 122-123).

5. Laddad R., Johnson R. AspectJ in Action: Enterprise AOP with Spring Applications. Manning Publ., 2009, 568 p.

6. Gradecki J.D., Lesiecki N. Mastering AspectJ: Aspect-Oriented Programming in Java. Wiley Publ., 2003, 456 p.

7. The Don't Repeat Yourself Principle and the Wormhole Anti-Pattern. Available at: http://codebetter.com/jeremymil-ler/2007/03/22/the-dont-repeat-yourself-principle-and-the-wormhole-anti-pattern/ (accessed February 28, 2016).

8. Walls C. Spring in Action. Manning Publ., 2011, 424 p. (Russ.ed.: Moscow, DMK Press Publ., 2013, 752 p.).

9. Booch G. Object-oriented analysis and design with applications. Pearson Education Publ., 2000 (Russ.ed.: Moscow, Williams Publ., 2010, 720 p.).

10. Repin V.V., Eliferov V.G. Protsessny podkhodk upravleniyu. Modelirovanie biznes-protsessov [Process Approach to Management. Modeling Business Processes]. Moscow, Mann, Ivanov i Ferber Publ., 2013, 544 p.

i Надоели баннеры? Вы всегда можете отключить рекламу.