Будущее программной архитектуры
Предсказывать трудно — в особенности предсказывать будущее. Нильс Бор Историю программирования правомерно рассматривать как последовательное расширение средств выражения сложной функциональности. Вначале был язык ассемблера с узким набором элементарных абстракций, выражавших расположение в физической памяти (относительно адреса в некоем регистре базы), и машинный код исполнения примитивных арифметических операций и операций пересылки. Но даже в таких примитивных условиях у программ была архитектура. Ее элементами выступали блоки кода, связанные физической близостью друг к другу, ветвящимися операторами или подпрограммами с соединителями в виде конструкций ветвления и возврата. В первых языках программирования эти конструкции утвердились, и в роли соединителей уже выступали точки с запятой, операторы перехода и параметрические вызовы функций. 1960-е стали десятилетием подпрограмм. В 1970-х годах, в связи с нежеланием разработчиков ограничиваться одним- единственным атрибутом качества — корректным функционированием, программы стали структурировать. На основе анализа потоков данных, диаграмм отношений «сущность-связь», информационной закрытости и ряда других принципов и методик формировались сотни проектных методологий. Каждая из них предполагала создание подпрограмм и коллекций подпрограмм с возможностью рационализации их функциональности в категориях атрибутов качества разработки. Эти элементы назывались модулями. В области соединителей изменений не намечалось, но в то же время некоторые новые модульные языки программирования расширили возможности их создания. Абстракции, встраивавшиеся в модули, со временем усложнялись и расширялись, что, в конечном итоге, привело к появлению первых повторно используемых модулей. Пакетировались они таким способом, который, теоретически, исключал необходимость изучения их внутреннего содержания. Таким образом, 1970-е стали десятилетием модулей. В 1980-х модульные языки программирования, принцип информационной закрытости и некоторые родственные методологии оформились в концепцию объектов. Объекты получили громадное распространение, а наследование обогатило ассортимент (не относящихся к периоду прогона) соединителей. В 1990-х годах появились первые стандартные объектные архитектуры, выраженные поначалу в виде каркасов. В рамках объектной технологии сформировался стандартный словарь элементов, подтолкнувший разработку новых инфраструктур для связывания коллекций элементов. Возможности абстракций неуклонно увеличивались. Благодаря этому домашние вычислительные платформы сегодня позволяют обрабатывать сложные сущности — электронные таблицы, документы, графические изображения, звуковые ролики и базы данных — как «черные ящики», которые можно без труда включать в экземпляры друг друга. Отодвигая отдельные элементы на второй план, архитектура имеет дело с их расположением и взаимосвязью. Необычайно широкие возможности взаимодействия возникают именно благодаря подобного рода абстракции, а индивидуальные элементы здесь играют подчиненную роль. В текущем десятилетии фиксируется стремительное развитие промежуточного программного обеспечения и информационно-технологической архитектуры, превращающейся в стандартную платформу. Безопасность, надежность и службы обеспечения производительности, реализуемые сегодня в коммерческих элементах, десять лет назад казались достижимыми только лить при индивидуальной разработке. Основные перечисленные выше этапы программирования изображены на рис. 19.1 в виде диаграммы. Рис. 19.1. Хронологические этапы развития типов абстракции
Вот на таком этапе мы находимся в данный момент. У нас нет повода усомниться в том, что тенденция к созданию более крупных и функциональных абстракций продолжится. Сегодня уже существуют генераторы (generators) для таких сложных и ресурсоемких приложений, как системы управления базами данных и авиационные электронные системы. Наличие в предметной области генератора есть первый признак перехода средств языка программирования в этой области на новый, более высокий уровень. Выражение «системы систем» (systems of systems), акцентирующее способность систем к взаимодействию и свидетельствующее об очередном повышении возможностей абстракций, употребляется все чаще. Далее мы хотели бы еще раз пробежаться по рассмотренным в этой книге проблемам. Полностью согласные с Нильсом Бором, мы не пророчествуем — мы просто высказываем свои надежды. Перечисляя одну за другой тематические области программной архитектуры, мы поговорим о тех аспектах, которые па данный момент разработаны не так хорошо, как хотелось бы, н выделим проблемы. над которыми исследовательскому сообществу придется основательно потрудиться. Начнем с обобщения сведений об архитектурно-экономическом цикле (Architecture Business Cycle, ABC), затем обсудим процесс создания архитектуры и ее отношения с жизненным циклом и, наконец, поговорим о том, как компоненты и компонентные каркасы видоизменяют задачи архитектора. 19.1. Снова архитектурноэкономический цикл В главе 1 мы заявили, что архитектурно-экономический цикл будет объединяющей темой всей книги. По мере изложения мы конкретизировали и развивали ее, старались донести некоторые принципы создания, представления, оценки и разработки архитектуры. Для того чтобы превратить изучение программной архитектуры в окончательно сформировавшуюся область исследований, в ней должны существовать разработанные, фундаментальные направления с практическими результатами. В этом контексте имеет смысл выделить и обсудить четыре версии ABC, которые, по нашему мнению, заслуживают серьезной разработки в будущем. ♦ Простейший сценарий, согласно которому отдельно взятая компания создает единичную архитектуру для единичной системы. ♦ Сценарий, согласно которому компания создает на основе архитектуры не одну, а несколько систем, связанных фондом общих средств, и организует их в рамках линейки продуктов. ♦ Сценарий, согласно которому в результате совместных усилий большей части игроков сообщества создается стандартная или эталонная архитектура, на основе которой впоследствии создаются многочисленные системы. ♦ Сценарий, согласно которому архитектура, подобно Всемирной паутине, приобретает чуть ли не вселенское распространение, и, соответственно, круг ее разработчиков на порядки перерастает масштабы отдельной организации. Каждая из перечисленных разновидностей архитектурно-экономического цикла состоит из тех же элементов, что и его первоначальная версия: заинтересованных лиц, технической базы, базы опыта, набора требований, которые необходимо реализовать, архитектора или архитекторов, одного или нескольких вариантов архитектуры, одной или нескольких систем. Вариантность архитектурно-экономического цикла обусловливается коммерческим контекстом, емкостью рынка и поставленных задач. По нашему мнению, в будущих моделях определения стоимости и эффективности программного обеспечения (в этом смысле CBAM — это только начало) будут предусмотрены все эти версии архитектурно-экономического цикла. В частности, они должны учитывать стратегические инвестиции, в большинстве случаи связанные с процессом разработки продуктов на основе архитектуры, и прогнозировать количественный эффект создания архитектуры.
|