При разработке сложной системы значительная часть времени
уходит на поиск данных, уже сформированных кем-то из группы
разработчиков или привнесённых в группу извне, а значительная
часть ошибок возникает из-за того, что эти данные не найдены или
неверно интерпретированы, либо из-за того, что не пришла в голову
мысль, что они уже где-то есть. Чтобы минимизировать подобные
потери, следует устанавливать и жёсткими мерами поддерживать на
проекте развитую и чёткую систему документирования и информацион-
ного взаимодействия. Такая система в значительной степени универ-
сальная, и особенности конкретного проекта требуют изменения её
только в малой части.
Качество документации на проекте должно быть адекватно уровню
сложности этого проекта, иначе проект превратится из сложного в
сверхсложный и, если не застопорится совершенно, то значительно
сбавит темп продвижения вперёд.
Работа над проектом должна начинаться с разворачивания системы
документации -- существующей вначале в виде совокупности пустых
"ёмкостей", которые будут постепенно заполняться данными.
Любое изменение в разрабатываемой, развиваемой, поддерживаемой
программной системе должно сопровождаться соответствующим измене-
нием в документации на систему. Если это правило хотя бы иногда
нарушается, документация оказывается всё менее адекватной
системе, из-за чего использование этой документации становится
причиной ошибок.
* * *
Все сложные решения должны документироваться. В том числе
должны фиксироваться основания для принятия этих решений. Также
должны кратко помечаться отброшенные варианты и их недостатки.
В противном случае через некоторое время будет трудно вспомнить
причины того или иного выбора, будет тратиться на это время, и
будет риск возвращения к тому, что в своё время оказалось на
правильных основаниях отвергнутым.
Должны документироваться, среди прочего, решения, принимаемые
отдельными специалистами в пределах их компетенции -- не требую-
щие согласования с кем-либо.
Через такое документирование достигается, среди прочего, взаи-
мозаменяемость участников проекта, и руководитель проекта оказы-
вается лучше защищён от возможных капризов отдельных работников.
* * *
Система документации должна выстраиваться по принципу минималь-
ного разнообразия оформления и языка.
Надо различать архитектуру системы документации и техническую
реализацию этой архитектуры в виде электронных документов, под-
держиваемых программными средствами определённых типов на техни-
ческих устройствах определённых типов.
Документы разделяются, среди прочего, на основные и производ-
ные. Производные документы содержат данные из основных, представ-
ленные в форме, которая более удобна для выполнения некоторой
работы. Они дублируют сведения, но это дублирование является
источником эффективности. Пренебрежение возможностью создания
таких документов под тем предлогом, что сведения уже где-то
зафиксированы, приводит к потере времени.
* * *
Система документации -- совокупность документов на техническую
систему, выполненных в едином стиле и связанных взаимными
ссылками.
Прототип системы документации -- полный набор заготовок доку-
ментов на систему и на проект её разработки: с оглавлениями,
стандартными элементами содержания, вставленными подсказками по
заполнению. Прототип включает в себя заготовки не только выходных
документов, но также и промежуточных (внутренних). Он представля-
ет собой сложное изделие -- предмет самостоятельной разработки и
возможный товар для широкой продажи.
Прототипы систем документации могут различаться между собой
тем, что ориентируются на документируемые системы разных типов и
разных уровней сложности, на разное техническое обеспечение
документирования. Они могут также различаться стилем оформления.
Когда начинается программный проект, для него должен быть вы-
бран наиболее подходящий прототип системы документации -- по ана-
логии с тем, как должен быть выбран прототип для разрабатываемой
программной системы.
Система документирования -- это набор инструментов для разра-
ботки и поддержания системы документации.
* * *
При разработке сложной технической системы документацию к ней
лучше упорядочивать по иерархическому принципу. В этом случае
основным документом является список других документов, относящих-
ся к разработке системы, с указанием 1) их типа, 2) даты их ак-
туальной версии, 3) прав доступа к ним, 4) мест их расположения.
Если заранее неизвестно, где отыскать те или иные данные, поиск
начинается с обращения к этому списку. Через него обеспечивается
ЦЕЛОСТНОСТЬ системы документирования.
Те или иные сведения о программной системе должны не просто
присутствовать в документации, выражаться в программном коде или
в комментариях к нему: эти сведения должны быть ЛЕГКОДОСТУПНЫМИ
на основе простой стратегии поиска, иначе решение различных
проблем в системе будет дополнительно отягощаться проблемой
поиска нужных данных.
Причины плохого документирования системы:
1) лень, непредусмотрительность, нестратегичность мышления;
2) непонимание значимости документации (следствие упрощённости
представлений о технологии разработки сложных систем);
3) стремление облегчить текущую работу в ущерб будущей работе;
4) надежда на собственную память;
5) стремление получить за счёт своей хорошей памяти преимущество
перед коллегами (некоторая конкуренция между коллегами почти
неизбежна);
6) недостаточное знание языка, на котором ведётся документация
на проекте;
7) неспособность к написанию внятных текстов (независимо от
языка);
8) нежелание делиться сведениями с коллегами (следствие стремле-
ния обеспечить собственную незаменимость).
Люди с хорошей памятью более склонны пренебрегать документиро-
ванию, чем люди с плохой памятью, и способны в конечном счёте
если не застопорить сложный проект, то сделать его сверхсложным,
так что разбираться в нём смогут лишь им подобные, да и то ценой
больших затрат времени.
Оставлять написание исчерпывающей и качественной документации
напоследок, на тот период, когда проектные решения в основном уже
устоятся, значит существенно затруднять выработку и корректировку
проектных решений.
Надо твёрдо устанавливать, в каких своих частях разрабатываемая
программная система является документируемой и в каких -- самодо-
кументируемой, то есть понятной на основе её кода и комментариев
к нему.
* * *
Документы могут представлять собой наборы данных (файлы),
находящиеся в некоторой области на сервере или "мэйнфрейме",
доступной для всех участников проекта.
!MAIN -- Main document: список других документов;
CODING -- Coding rules;
DECISIOS -- Decisions: основные решения по проекту;
DICTIONR -- Dictionary;
ENVIRONM -- Environments;
FUNCTIS -- Functions;
INCLUDES -- Includes;
INSTRUMS -- Instruments;
LIBRARIS -- Libraries;
MESSAGES -- Messages of the system;
MODULS -- Moduls;
NAMING -- Naming rules;
NEWS -- News: новости на проекте;
PERSONS -- Persons;
REPORTS -- Personal weekly reports
ROLES -- Roles;
SCREENS -- Screens;
SUBJECT -- Subject area descriptions;
TESTCAS -- Testcases;
USERIDS -- UserIDs;
Содержанием документов этого списка может быть набор конечных
данных или список других документов.
* * *
Группы документов:
отношения с заказчиком;
архитектура;
техническая реализация;
тестирование;
инструкции пользователям;
инструкции по установке;
инструкции по поддержке;
планы;
отчёты;
соглашения по сопряжению;
описания используемых инструментальных средств;
описания сопрягаемых систем.
* * *
Важная часть документации -- таблицы соответствий между различ-
ными компонентами программной системы, проекта. Если установлены
эффективные правила именования компонентов, потребность в таких
таблицах уменьшается, но не устраняется полностью. Могут исполь-
зоваться, к примеру, следующие таблицы соответствий:
экраны -> программы, работающие с этими экранами;
программы -> таблицы баз данных, к которым эти программы
обращаются;
функции -> головные программы, реализующие эти функции;
программы -> разработчики этих программ;
задания на создание таблиц базы данных -> таблицы базы
данных, создаваемые этими заданиями.
...............................................................
...............................................................
Александр Бурьяк.