Kategorien: Alle - язык - производительность - анализ - методология

von Вика Белых Vor 8 Monaten

69

Технологии программирования (Software Engineering) Классические технологические процессы

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

Технологии программирования (Software Engineering)
Классические технологические процессы

Технологии программирования (Software Engineering) Классические технологические процессы

2.6. Ввод программы в действие

Следует отметить, что в целом ряде случаев (например, работа с программой через Интернет) такое действие, как инсталляция (установка) программы, уходит в прошлое. Тем не менее, приведем правила хорошего тона при подготовке инсталляции.
Следует убедиться, что инсталлятор включает возможность автоматического удаления программы с диска. Программа без деинсталлятора создает массу лишних проблем своим пользователям.
Следует всегда включать в архив файл README, который должен содержать подробную информацию о программе. Он должен быть доступен пользователю еще до начала инсталляции.
Следует, даже пользуясь инсталлятором, который упаковывает программу в один самораспаковывающийся файл, дополнительно сжимать его и распространять именно zip-архив. Не следует использовать другие архиваторы, даже если они сжимают лучше, поскольку их пользователь может не иметь.
В последнем случае есть несколько основных разновидностей доставки.
Возможность скачать из сети программу и установить ее на своих компьютерах, подобно установке программы, поставляемой в коробке. Интернет неожиданно просто решает проблему распространения программного обеспечения и доставки его до пользователя. На смену десятилетию "коробочных продуктов" (1985-1995) пришли "продукты из Интернета". Причем в Интернете есть две группы программных продуктов:

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

свободно распространяемые программные продукты;

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

2.5. Тестирование и отладка

Отладка программных продуктов
Обратим особое внимание на два достаточно простых случая отладки. Их анализ может быть достаточно легко выполнен при помощи пошагового отладчика.

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

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

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

Подготовить новые исходные данные и провести эксперимент, который позволит доказать или опровергнуть гипотезу.

Сформулировать некоторую гипотезу, которая объясняет получение таких результирующих данных.

Следует начать с изучения уже доступных исходных и результирующих данных.

Тестирование программных продуктов
Тестовые данные

Отслеживание ошибок

Проблема или ошибка может быть рассмотрена как некоторый объект в системе, который может находиться в одном из восьми состояний.

Подтверждено исправление ошибки.

Исправление интегрировано в основное пространство.

Выполнено исправление ошибки.

Принято решение о начале работы над исправлением.

Выполнен окончательный анализ проблемы или ошибки.

Понятна причина, вызвавшая ошибку.

Выполнен первичный анализ (эксперт подтвердил факт наличия ошибки).

Проблема или ошибка зарегистрирована.

Тестирование программ в процессе разработки

Поскольку в процессе разработки приходится тестировать еще не завершенную программу, все подходы к тестированию делятся на две группы.

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

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

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

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

использование результатов, полученных при помощи другой программы, которой мы доверяем.

вычисление вручную;

использование справочников;

Для тестирования программ методом черного ящика [Канер, Фолк, Нгуен 2000] готовятся определенные группы тестов.

Для тестирования тех утверждений, которые приводятся в документации.

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

Для тестирования граничных значений.

Для тестирования классов эквивалентностей. Классы эквивалентностей позволяют вместо большого количества тестов использовать лишь их небольшое подмножество. Каждый тест представляет набор тестов, на которых программа ведет себя одинаково. Существует два основных типа классов эквивалентностей.

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

Класс корректных тестовых случаев, отражающих типичную "нормальную" ситуацию.

Типичные ошибки

Обратим внимание на две категории наиболее распространенных ошибок программистов.

Ошибки специального вида, особенно трудные для диагностирования.

Исчезающие ошибки.

Ошибки, связанные с неправильным результатом операций.

Ошибки, связанные с применением препроцессора.

Ошибки при написании параллельных программ. Например, ошибки в расстановках семафоров.

Ошибки общего (несинтаксического) характера, остающиеся в программах после выполнения синтаксического контроля.

Отсутствие начального обнуления элементов.

Ошибки при работе с массивами.

Ошибки в описании переменной. Например, отсутствие инициализации переменной.

Ошибки ввода-вывода.

Ошибки при работе с данными.

Ошибки в циклах. Например, неверные границы начала и конца.

Группа логических ошибок. Например, неполный учет возможных условий или неверное указание ветви алгоритма после проверки условия.

Существуют также разновидности тестирования.

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

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

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

Существуют две основные стратегии тестирования.

Тестирование программы как прозрачного (белого) ящика подразумевает знание исходного кода программы и полный доступ к нему.

Тестирование программы как черного ящика, при котором программа рассматривается как объект, внутренняя структура которого неизвестна.

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

2.4. Программирование (реализация)

Выбор языка программирования
На выбор языка программирования влияют четыре основных фактора.

Степень знакомства программистов с языком программирования. Результаты исследований говорят о том, что производительность программиста, работавшего на некотором языке более трех лет, возрастает на треть по сравнению с программистом такого же уровня, но без опыта работы на данном языке [Boehm 1981]. Исследование специалистов компании IBM показало даже более существенные результаты. Программисты с длительным опытом программирования на некотором языке имеют производительность в три раза большую, чем программисты с минимальным опытом программирования [Walston, Felix 1977].

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

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

Сравнительная пригодность языка программирования для данной задачи.

Защитное программирование
Теперь дадим несколько рекомендаций по защитному программированию [Тассел 1985].

Проверяйте коды возврата функций.

Проверяйте длину элементов информации.

Включайте автоматические проверки (например, контроль переполнения или потери точности).

Контролируйте итоги вычислений.

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

Делайте проверку области значений переменных.

Существуют три основных принципа защитного программирования.

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

Немедленное обнаружение. Каждая ошибка должна быть выявлена как можно раньше, это упрощает установление ее причины.

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

Стиль программирования
Языковые детали

Рекомендации по написанию определения функций.

Если часть then или else состоит из простого оператора, то открывающая и закрывающая фигурные скобки могут быть опущены.

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

Закрывающая фигурная скобка находится на том же уровне отступа, что и начало условного оператора.

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

По одному пробелу следует оставлять перед и после круглых скобок условия.

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

Определение функции всегда начинается в самом левом столбце файла.

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

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

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

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

Рекомендации по объявлению переменных.

Если переменная является указателем, то символ * следует присоединять к типу.

За типом переменной должны следовать пробел, имя переменной и комментарий с кратким описанием переменной.

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

В каждом объявлении должна объявляться только одна переменная.

Рекомендации по написанию выражений.

Если выражение переносится на следующую строку, то знак бинарной операции следует оставить на первой строке.

Старайтесь размещать выражение на одной строке.

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

Унарные операторы не следует отделять от операнда пробелом, если только этого не требуют правила языка.

Бинарные операторы должны быть отделены от операндов одним пробелом.

Рекомендации по выравниванию.

Табуляционный отступ равен восьми пробелам.

Стандартная величина отступа равна четырем пробелам.

Лексические соглашения

Строковые комментарии следует использовать для коротких заметок в одну-две строки.

Блочные комментарии следует применять для описания дополнительной информации о файле, классе, функции или переменной.

Имена перечислимых типов могут иметь единый префикс. Приведем рекомендации по употреблению комментариев.

Имена функций должны быть активными, т. е. базироваться на активном глаголе, за которым следует существительное.

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

Имена, используемые в ограниченном контексте, могут быть очень короткими. Традиционно имена i и j используются для обозначения счетчиков, р и q для указателей, s для строковых, a ch для литерных переменных. В данном случае ясность достигается краткостью.

Смысл всех имен должен быть понятен при чтении программы.

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

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

Не следует в одной и той же программе использовать имена, различающиеся лишь написанием букв - строчной или прописной.

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

Не начинайте и не заканчивайте идентификаторы символом подчеркивания.

Структура файлов

Далее представлены рекомендации по организации файлов.

Для файлов кода на языке C++ рекомендуется такая последовательность:

импортируемые интерфейсы;

комментарий к файлу;

Следует соблюдать следующий порядок в заголовочных файлах программы на языке C++:

завершающая защитную проверку директива условной компиляции

объявления;

импортируемые интерфейсы. Как правило, они определяются с помощью tinciude-директив;

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

комментарий к файлу, который оформляется как блочный комментарий. Комментарий может начинаться указанием на лицензию, которая определяет права собственности на данный файл. Комментарий обычно продолжается идентификационной строкой системы управления версиями файлов. Например, для утилиты SCCS (см. 'разд. 5.6.1.1) строка может выглядеть так: %Z%%M% %I% %E% и включать символы идентификации SCCS, имя файла, номер версии и дату последней модификации. Комментарий должен содержать краткое описание файла;

Опишем рекомендации по длине строк.

Лучше всего, если длина строк программы значительно короче 80 символов.

Строки не должны быть длиннее 80 символов. Обоснование: Многие текстовые редакторы и системы печати текстов программ ориентированы именно на это максимальное количество символов в строке. Исторически это объясняется текстовым режимом отображения символов на экране: 25 строк по 80 символов.

Приведем рекомендации по именованию файлов.

Все файлы должны иметь различные имена, даже если они находятся в разных каталогах.

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

Заголовочные файлы должны иметь расширение h. Файлы с программой на языке С должны иметь расширение с, а с программой на языке C++ - ее (в операционной системе Unix) или cpp (в операционной системе Windows).

Это не набор обязательных правил, установленный раз и навсегда. Брайан Керниган (Brian Kernighan) и Роб Пайк (Rob Pike) [Керниган, Пайк 2001] уточняют, что код должен быть прост и понятен, т. е. обладать следующими свойствами:

отсутствие хитрых трюков и необычных конструкций.

развернутые комментарии;

аккуратное форматирование;

осмысленные имена;

использование соглашений, принятых в языке разработки;

естественные выражения;

очевидная логика;

2.3. Анализ требований и проектирование

Подходы к ведению анализа и проектирования
Подход предлагает механизм поддержки моделей состояний. Для этого вводятся четыре архитектурных класса.

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

Активный экземпляр. Это абстрактный класс, из которого все экземпляры, имеющие модель состояний, наследуют их текущее состояние.

Конечная модель состояний, связывающая все экземпляры перехода, которые составляют одну модель состояний.

Переход, описывающий каждый переход для всех моделей состояний в программе.

Для анализа больших предметных областей используются диаграммы, по смыслу близкие к следующим диаграммам языка UML:
Подход Шлеер-Меллора (Sally Shlaer and Stephen Mellor) использует три группы средств для создания модели предметной области.

Моделирование процессов - для определения функций, которые система должна выполнить. Используются:

диаграммы последовательности.

Моделирование состояний - для определения, зависящего от времени поведения системы. Используются диаграммы состояний.

Информационное моделирование - для определения отношений между данными (информацией). При этом используется один тип диаграмм: Диаграммы классов.

Существует несколько рекомендаций, связанных с данным подходом:

80% проектов можно воплотить, используя 20% средств языка UML. Как правило, наиболее часто используют диаграммы классов и диаграммы деятельности.

не следует стремиться к построению диаграмм всей системы;

К ним добавляются следующие типы диаграмм, которые определяют взаимодействие:

диаграммы кооперации.

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

диаграммы деятельности.

Подход на основе универсального языка моделирования UML (Unified Modeling Language) включает следующие основные типы диаграмм:

две диаграммы реализации:

диаграммы развертывания.

диаграммы компонентов;

три диаграммы поведения (две последние из них также называют диаграммами взаимодействия):

диаграммы кооперации;

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

диаграммы деятельности;

диаграммы состояний;

диаграммы классов;

диаграммы вариантов использования;

Перечислим основные подходы к ведению объектно-ориентированного анализа и проектирования и рассмотрим подробно некоторые из них.

Подход Ивара Якобсона (Object-Oriented Software Engineering - OOSE).

Подход Джеймса Рамбо (Object Modelling Technique - ОМТ).

Подход Град и Буча.

Подход Шлеер-Меллора.

Подход на основе языка UML.

Подход Джексона (Michael Jackson) ориентирован на данные. Базовая процедура проектирования включает четыре этапа [Калянов 1996], [Кинг 1991].

Этап проектирования текстов. Трансляция построенной модели программы в текстовый вид с добавлением ряда логических условий для управления выполнением циклов и выбором данных.

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

Этап проектирования программ. Формирование структуры программы комбинированием структур данных. Идентификация всех связей между компонентами структур данных.

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

Подход Гейна-Сарсона (Chris Gane and Tom Sarson) очень близок к предыдущему. Статистика утверждает, что он применяется в 20,2% случаев [Калянов 1996]. Главной отличительной чертой подхода является наличие этапа моделирования данных, определяющего содержимое хранилищ данных в диаграммах потоков данных в третьей нормальной форме. Этот этап включает:

представление всей информации по модели в виде связанных нормализованных таблиц.

анализ отношений между данными и построение соответствующей диаграммы связей между элементами данных;

построение списка элементов данных, располагающихся в каждом хранилище данных;

В нем интегрированы следующие средства:

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

словари данных, являющиеся каталогами всех элементов данных, присутствующих в диаграммах потоков данных;

диаграммы потоков данных;

Перечислим основные подходы к ведению структурного анализа и проектирования и рассмотрим подробно некоторые из них.

Подход промышленного метода Oracle.

Подход промышленной технологии DATARUN.

Подход Мартина.

Подход Варнье-Орра.

Подход Джексона.

Подход Константайна.

Подход Гейна-Сарсона.

Подход Йордона и ДеМарко.

Как правило, подходы используют две основные группы средств моделирования [Вендров 2000].

Диаграммы, моделирующие данные и их отношения. Например, диаграммы "сущность-связь".

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

Итак, комбинации структурных методов образуют структурные подходы. Можно выделить три группы структурных подходов на основе порядка построения модели [Калянов 1996].

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

Подходы, ориентированные на данные. Для таких подходов первичны входные и выходные данные, а функциональные (процедурные) компоненты вторичны.

Процедурно-ориентированные подходы, в которых первично проектирование функциональных компонентов.

Методы анализа и построения спецификаций

Существуют четыре разновидности сообщений.

Для возврата из вызову процедуры.

Для асинхронного сообщения между двумя объектами в некоторой процедурной последовательности.

Для обозначения простого (не вложенного) потока управления.

Для вызова процедур, выполнения операций или обозначения отдельных вложенных потоков управления.

Диаграмма имеет два измерения.

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

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

Процессы могут быть объединены в четыре основных группы.

Процессы проверки, которые проверяют условие и исполняют один из нескольких условных выводов управления.

Процессы преобразования, основной целью которых является вычисление или преобразование данных.

Генераторы событий, создающие событие, как результат работы.

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

Для представления этого жизненного цикла предлагается модель состояний, состоящая из:

множества действий; действие - это деятельность или операция, которая должна быть выполнена экземпляром, когда он переходит в некоторое состояние.

множества правил переходов; правила определяют, какое новое состояние достигается, когда с объектом в данном состоянии происходит некоторое событие;

множества событий; событие - абстракция инцидента или сигнала в реальном мире, который сообщает о перемещении чего-либо в новое состояние;

множества состояний; состояние - положение объекта, в котором применяется определенный набор правил, линий поведения, предписаний и физических законов;

Диаграмма состояний (statechart diagram) отражает модель поведения объектов в реальном или абстрактном мире. Все объекты имеют некоторый срок жизни:

и, наконец, исчезают или умирают.

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

сначала они появляются или создаются;

Диаграмма вариантов использования (use case diagram) - сценарий, позволяющий лучше понять требования к системе. В состав диаграммы входят:

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

актер (actor) - любая внешняя по отношению к моделируемой системе сущность, которая взаимодействует с системой и использует ее функции и возможности;

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

Класс служит для обозначения множества объектов, которые обладают одинаковой структурой, поведением и отношением с объектами из других классов. Между классами существуют четыре типа отношений.

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

Зависимости, когда изменение одного элемента может потребовать изменения другого.

Обобщения, представляющие иерархическое строение и наследование классов.

Ассоциации, представляющие некоторое отношение или связь.

Карты класс-ответственность-кооперация (class-responsibility-collaboration) предназначены для описания классов. Первоначально они были созданы для обучения объектному языку

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

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

Перечислим основные методы ведения объектно-ориентированного анализа и рассмотрим подробно некоторые из них.

Диаграммы последовательности.

Диаграммы состояний.

Диаграммы классов.

Диаграммы вариантов использования.

КОК-карты (класс-ответственность-кооперация).

В состав диаграммы входят:

дуги, связывающие блоки вместе и изображающие взаимодействия и взаимосвязи между ними. Место соединения дуги с блоком определяет тип интерфейса:

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

результаты (выходная информация) показаны с правой стороны;

входная информация, подвергающаяся обработке, показана с левой стороны блока;

управляющая информация входит в блок сверху;

блоки, изображающие активность моделируемой системы;

Компонентами диаграммы потоков данных являются:

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

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

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

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

Перечислим основные методы ведения структурного анализа и рассмотрим подробно некоторые из них.

Диаграммы функционального моделирования.

Диаграммы декомпозиции.

Диаграммы зависимости.

Сети Петри.

Таблицы решений.

Диаграммы потоков управления.

Диаграммы потоков данных.

Проектирование модулей (проектирование "в малом")

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

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

Спецификации, показывая роли классификаторов и ассоциаций в рассматриваемом взаимодействии.

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

Диаграммы развертывания.

Диаграммы компонентов.

Диаграммы кооперации.

При создании таких моделей рассматривают понятия:

Атрибут - абстракция одной характеристики, которой обладают все абстрагируемые как объект сущности. Атрибуты бывают:

вспомогательные - для связи экземпляра одного объекта с экземпляром другого.

указательные - для дачи имени или обозначения экземпляру;

описательные - представляющие факты, внутренне присущие каждому экземпляру объекта;

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

M:N (многие-ко-многим);

1:М (один-ко-многим);

1:1 (один-к-одному);

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

существенно-ограниченное отношение используется, когда соответствующие сущности взаимозависимы в системе.

ограниченное отношение представляет собой условное отношение между сущностями;

неограниченное отношение представляет собой безусловное отношение, которое существует до тех пор, пока существуют относящиеся к делу сущности;

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

ассоциированная сущность представляет данные, которые ассоциируются с отношениями между двумя и более сущностями.

зависимая сущность представляет данные, зависящие от других сущностей в системе. Она всегда имеет отношения с другими сущностями;

независимая сущность представляет независимые данные, которые всегда присутствуют в системе. Отношения с другими сущностями у нее могут отсутствовать;

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

Псевдокод.

Схемы экранов.

Блок-схемы.

Диаграммы переходов состояний.

Диаграммы Варнье-Орра.

Диаграммы деятельности.

Структурные карты.

Диаграммы "сущность-связь".

Проектирование архитектуры (проектирование "в большом")
Объектно-ориентированная методология

Проектирование архитектуры для объектно-ориентированной методологии включает следующие основные методы [Шлеер, Меллор 1993]:

метод наведения мостов.

метод проектирования предметных областей;

Структурная методология

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

Анализа сообщений - при котором анализируются потоки данных, обрабатываемые модулями.

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

Проектирование архитектуры (проектирование "в большом") для структурной методологии включает следующие основные методы:

метод расширения ядра.

метод восходящего проектирования;

метод нисходящего проектирования;

Отступление "о классификации всего сущего"
Классифицировать можно даже ненаблюдаемые объекты. Их можно разбить на четыре категории, расположенные в порядке убывания научного интереса, который они представляют [Физики 1968].

Явления, ненаблюдаемые в обществе воспитанных людей (например, ковыряние в носу).

Явления, ненаблюдаемые в природе (например, потомство от стерильных кроликов).

Явления, ненаблюдаемые в принципе (например, абсолютная скорость).

Явления, ненаблюдаемые по определению (например, невидимый свет).

Большинство окружающих нас объектов относится к категориям, рассмотренных в книге [Шлеер, Меллор 1993].

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

Инциденты - абстракции чего-то произошедшего или случившегося.

Роли - абстракции цели или назначения человека, части оборудования или организации.

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

Отступление "об архитектуре"
Мэри Шоу (Mary Shaw) и Дэвид Гарлан (David Garlan) предложили использовать каталог архитектурных стилей [Shaw, Garlan 1996].

Вызов с возвратом:

слойный.

объектно-ориентированный;

главная программа и подпрограммы;

Виртуальные машины:

системы с правилами.

интерпретатор;

Централизованные данные:

классная доска.

хранилище;

Поток данных:

каналы и фильтры.

пакетно-последовательный;

Независимые компоненты:

системы с событиями: неявный вызов и явный вызов.

взаимодействующие процессы;

Кроме этих четырех часто используются и другие структуры.

Структура классов.

Структура использования.

Структура потоков управления.

Структура потоков данных.

Структура вызовов.

Можно определить четыре структуры, которые в совокупности описывают программную архитектуру [Ахтырченко, Леонтьев 2001].

Физическая структура, определяющая отображение элементов программного средства на аппаратное обеспечение.

Процессная структура, описывающая поведение системы во время ее исполнения.

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

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

Выделяют следующие классы архитектур программных продуктов [Майерс 1980], такие как:

коллектив параллельно выполняемых программ.

слоистая программная система;

комплекс автономно выполняемых программ;

цельная (монолитная) программа;

И, наконец, еще одно определение содержится в работе [Буч, Рамбо, Джекобсон 2000]: Архитектура - это совокупность существенных решений, касающихся:

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

составления из этих структурных и поведенческих элементов все более и более крупных подсистем;

поведения этих элементов, определенного в процессе взаимодействия с другими элементами;

выбора структурных элементов, составляющих систему, и их интерфейсов;

организации программной системы;

Отступление "о спецификациях"
Существует два основных способа представления спецификаций:

Представление с помощью информационных объектов. Как правило, таким способом представляются модельные спецификации.

Текстовое представление, которое подходит для словесных и формальных спецификаций.

По уровню формализации выделим три класса.

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

Модельные (структурированные) спецификации, которые предполагают построение схем, диаграмм, других информационных структур.

Словесные спецификации, обработка которых может осуществляться обычным текстовым редактором.

В спецификациях программ имеет смысл выделить две существенно отличающиеся части.

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

Функциональные спецификации, описывающие функцию программы.

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

Объектная декомпозиция рассматривает структуру объектов и связей между ними, а также поведение системы в терминах обмена сообщений между объектами.

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

Проектирование должно проводиться на двух уровнях:

Детальное проектирование (проектирование модулей, проектирование "в малом").

Проектирование архитектуры (проектирование системы, проектирование "в большом").

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

2.8. Завершение эксплуатации

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

2.7. Эксплуатация и сопровождение

Теперь рассмотрим - как четыре основных класса задач по сопровождению решаются применительно к компиляторам.
Предупреждение проблем может быть проиллюстрировано ставшей уже классической "проблемой 2000 года".
Если усовершенствование и адаптация могут быть рассмотрены для многих компиляторов без указания на язык программирования, то коррекция ошибок в большой степени ориентирована на компилятор с конкретного языка программирования. Исключение составляют специфические ошибки оптимизатора и кодогенератора. Лишь небольшое количество исправлений в части анализа может быть одинаково применено ко всему набору родственных компиляторов и, как правило, связано с неверным взаимодействием этой части с компонентами (например, ошибочная генерация информации отладчика).
Усовершенствование компиляторов предполагает внесение в них изменений в интересах заказчика. Выделим несколько основных направлений усовершенствования.

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

Необходимость соответствия стандарту языка. В случае изменения стандарта или появления комментариев к стандарту, компилятор должен все эти изменения учитывать.

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

Повышение эффективности. Например, оптимизация алгоритмов семантического анализа.

Адаптация компиляторов предполагает их приспособление к изменившимся условиям работы системы. Все причины изменений могут быть сведены к трем основным.

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

Изменения в операционной системе. Например, операционная система может начать поддерживать многопоточное исполнение, начиная с некоторой версии.

Архитектурные изменения. Например, важнейшим типом адаптации является перенос компилятора на другую архитектуру.

Источниками ("возбудителями") основных классов задач сопровождения могут быть:
инженеры, сопровождающие компилятор (например, предлагая повысить эффективность компилятора).
разработчики взаимозависимых компонентов (например, отладчика);
пользователи компилятора, находящие ошибки;
Проиллюстрируем процесс сопровождения на примере таких программ, как компиляторы. Поскольку они имеют ряд особенностей, характерных для их сопровождения [Safonov 1996], то перечислим эти особенности в порядке от более общих к более специфическим.
Наличие стандартов на языки программирования.
Наличие устаревших алгоритмов.
Необходимость тщательного тестирования.
Наличие большого количества пользователей.
Функционирование на нескольких аппаратных платформах.
Существует ряд методов, которые помогают добиться высокого качества сопровождения.
Пассивное и активное сопротивление изменениям. За некоторое время до внесения изменения программист должен разослать письмо с описанием изменения и фрагментами изменяемого кода остальным участникам разработки. Программист сможет внести изменения только в следующих случаях:

если все одобрят изменение (в случае активного сопротивления).

если никто из коллег не выступит против (в случае пассивного сопротивления);

Самодокументируемость изменений.
Выделение области связности изменений. Следует четко представлять себе границы области, которая подвергается изменениям.
На выбор типа сопровождения влияют два фактора.
Стоимость сопровождения. При высокой стоимости сопровождения рекомендуется ориентироваться на реструктурирование и реинжиниринг, а при низкой - на незначительные изменения.
Класс решаемой задачи. Как правило, коррекция программы влечет незначительную степень вмешательства, а усовершенствование и адаптация - реструктурирование и реинжиниринг.
Для решения указанных задач выбирается один из следующих, наиболее подходящих типов сопровождения [Conger 1994], под которым будем понимать степень вмешательства в программу:
программирование заново.
реинжиниринг - перестройка существующего программного продукта. Обычно реинжиниринг применяется для приведения кода программы в соответствие с современными методологиями программирования (например, объектно-ориентированной);
реструктурирование кода - повторная разработка небольшой части программы. При этом интерфейс этой части с остальной программой остается неизменным;
незначительные (локальные) изменения',
Перечислим четыре основные класса задач, решаемых на этапе сопровождения.
Предупреждение проблем, которые могут возникнуть в будущем.
Коррекция или исправление ошибок.
Усовершенствование, заключающееся обычно в добавлении новых функций.
Адаптация, как правило, заключающаяся в модификации функций.

2.2. Управление

Современные подходы к управлению проектом
Перечислим основные практики.

Ответственность и подотчетность руководства перед сотрудниками. Такая мотивация сотрудников может значительно повысить производительность труда программистов.

Конфигурационное управление. Использование систем управления исходными кодами, позволяющих отслеживать изменения и дающих возможность вернуться к предыдущим версиям.

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

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

Контроль качества на детальном уровне. Промежуточные итоги должны подводиться еженедельно или даже ежедневно.

Планирование и управление на основе метрик. В основу планов и оценок должны быть положены числовые оценки - метрики, накопленные в предыдущих проектах.

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

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

Формальное управление рисками. Рекомендуется постоянно вести и анализировать списки основных важнейших рисков. У сотрудников не должно быть никаких иллюзий о допустимости рисков.

Для этой организации были сформулированы четыре главных цели ее работы.

Дать возможность быстро изучить и внедрить эти навыки в свою работу с помощью соответствующих методик обучения и программных систем.

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

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

Внедрить лучшие практические навыки создания программного обеспечения.

Методы управления проектами
Распределение работ

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

Определить последовательность работ для каждого исполнителя.

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

Методики оценок времени и затрат

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

формуле Симпсона: (О+4*Р+П/б.

формуле трапеций: (O+2*Р+П/4;

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

Методика норм работы. Учет ведется по нормам, определяемым как среднее значение времени, уходящее на данную работу в данной компании. Например, время, уходящее на разработку одной строки машинного кода.

Снизу вверх по составленному графику работ. Данные по трудозатратам и времени берем от исполнителей.

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

Планирование проекта

В рамках планирования управляющий решает также организационные задачи:

Определение интерфейсов приложения и планирование работ по детальному проектированию интерфейсов.

Назначение начальной и конечной дат работ.

Анализ документации на полноту, содержание, аккуратность.

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

Создание инфраструктуры управления.

Выявление критических путей.

Оценка рисков, связанных с конкретными задачами.

Определение времени выполнения задачи.

Проведение персональных назначений на задачи.

Определение зависимостей между задачами.

Распределение ответственности.

Выделение требуемых ресурсов.

Оценка затрат.

Составление графиков выполнения работ.

Построение списка задач.

Подчеркнем в виде неформальных требований необходимость наличия плана [Баранов 1998].

С помощью плана мы видим, когда цель, поставленная перед проектом, достигнута и проект заканчивается.

План - это точка отсчета для любых последующих изменений.

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

План определяет роль каждого человека в исполнении проекта.

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

Следующие два метода были разработаны параллельно и независимо.

Метод анализа и оценки программ ПЕРТ (PERT - Program Evaluation and Review Technique). Метод был разработан корпорацией "Локхид" и консалтинговой фирмой "Буз, Аллен энд Гамильтон" и применен в военно-морских силах США для ускорения разработки баллистической ракеты "Поларис" для подводных лодок.

Метод Критического Пути (МКП). Метод разработан фирмой "Дюпон де Немур". Первоначально назывался методом Уолкера-Келли, по именам создателей. Позже получил название МКП (СРМ - Critical Path Method).

С помощью этих методик руководитель проекта может:

координировать и контролировать выполнение работ для соблюдения календарного графика и завершения проекта в срок.

планировать завершение работ в нужные сроки в соответствии с требуемой последовательностью выполнения заданий;

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

Эволюция менеджмента
Особенности российского менеджмента

Духовность и психическое здоровье в основе деловой и поведенческой практики.

Профессионализм и мастерство. Коллективизм, поддержка и взаимопомощь.

Справедливость, основанная на понимании и принятии правовых норм.

Согласие и сотрудничество в обществе.

Честь и достоинство личности.

Социальные права личности.

Особенности японского менеджмента

Партнерство и сотрудничество в производственных отношениях.

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

Рабочие образуют "семью". Методы реализации принципа:

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

свободное время работники фирмы проводят вместе;

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

Рабочий стремится сделать свою работу лучше. Методы реализации этого принципа:

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

пожизненный найм работников;

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

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

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

кружки качества;

Особенности американского менеджмента

Контролируй исполнение.

Разделяй обязанности среди подчиненных.

Анализируй состояние инженеров, запросы рынка, процесс создания программного продукта.

Особенности европейского менеджмента

Подчиненность личных интересов общим. Интересы отдельного работника или группы не должны превалировать над интересами компании.

Корпоративный дух, т. е. гармония персонала, его сплочение.

Справедливость: сочетание доброты и правосудия.

Вознаграждение персонала, в том числе справедливая зарплата.

Дисциплина, т. е. послушание и уважение к достигнутым соглашениям между фирмой и ее работниками. Дисциплина предполагает также справедливо применяемые санкции.

Управление проектом
Абрахам Маслоу в 40-х годах XX века разделил потребности на пять категорий.

Потребность в самовыражении, заключающаяся в самореализации и росте как личности.

Потребности в уважении, включающие внутренние и внешние факторы уважения.

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

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

Физиологические потребности, являющиеся необходимыми для выживания.

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

Вторичные, являющиеся психологическими.

Первичные, являющиеся физиологическими по своей природе.

Существует ряд психологических принципов, лежащих в основе теории мотивации.

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

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

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

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

Обязанности управляющего

Еще раз обратимся к понятию "проект" и выделим четыре характеристики, делающих деятельность - проектом [Баранов].

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

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

Координированное выполнение взаимосвязанных действий. Здесь следует еще раз вспомнить сложность разработки программного продукта. Взаимосвязи в проекте не всегда очевидны. Некоторые задания должны выполняться строго последовательно, а некоторые - строго параллельно.

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

Исключительная ответственность менеджера заключается:

в ответственности за поступление средств.

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

в руководстве проектом и контролем его выполнения. Менеджер отвечает за ежедневное руководство данным проектом. Хороший менеджер отводит различные проблемы от группы, он "гасит" нагоняи от заказчика или вышестоящего руководства;

в управлении сотрудниками. Менеджер ищет и привлекает лучших специалистов и экспертов для решения возникающих проблем;

в организации взаимосвязей внутри организации;

Совместная деятельность менеджера и лидера проекта включает:

выбор наилучшей стратегии.

распределение работ;

планирование проекта;

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

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

Управляющий проекта - руководитель, обладающий организационными знаниями и опытом.

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

Инженеры. Именно инженеры заняты разработкой и созданием программного продукта.

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

Управляющие среднего уровня. В их задачу входит координация и стратегическое планирование деятельности структурного подразделения.

Высший менеджмент. В его задачу входит определение генеральной линии компании.

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

Стратегию человеческих отношений.

Маркетинговую стратегию.

Финансовую стратегию.

Оперативную стратегию.

Стратегию в области исследования и развития.

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

Тесное взаимодействие с группами поддержки и продаж.

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

Соблюдение многочисленных стандартов.

Принятие ясных и документированных решений.

Наилучшая расстановка приоритетов и ресурсов.

Наличие формализованной модели для разработки программного продукта.

2.1. Возникновение и исследование идеи

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

Функция

Руководитель проекта

0.3

Управление, разработка плана и содержания

Технический писатель

1.0

Подготовка документа

Инженер-разработчик

Ставка

0.1

Комментарии

Консультирующий инженер, реализующий OpenMP

Основные даты

Первый вариант полного "руководства" - август 1998 г.

Завершение проектирования "руководства" - апрель 1998 г.

Список основных документов

Спецификация OpenMP.

Зависимости

Выяснить право использовать фрагменты оригинальной спецификации OpenMP

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

Описание технического процесса

Включить информацию о "руководстве пользователя" в документ "Новости компании Компилятор++"

Проанализировать детали реализации, подготовить и включить в "руководство" соответствующие примеры программ.

Разработать проект "руководства" и определить способ его распространения

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

Исследовать возможность импортирования спецификаций OpenMP непосредственно из документа.

Сравнительный анализ
Пользователи документа
Описание особенностей поставки

Полная спецификация по OpenMP доступна в Интернете (http://www.openrap.org/).

Поскольку в данной реализации проекта "Волхов" не будут включены все особенности спецификации OpenMP, необходимо четко указать, какие из них будут реализованы, а какие нет.

Документ "Руководство пользователя по OpenMP" будет доступен как на сервере компании в сети Интернет, так и в бумажной копии.

Введение

Дата подготовки документа: 19 августа 1998 версия 1.3.

Название проекта: Руководство пользователя по OpenMP.

Краткий обзор
Одностраничный документ
Эдвард де Боно выделяет два типа мышления с соответствующими подходами решения задач
Непоследовательное мышление, которое может совершить скачок вперед, в сторону, в любое место вообще, чтобы неожиданно выработать решение.
Вертикальное мышление, которое начинает свой путь от выявления возможной причины той или иной проблемы или затруднения. Далее оно поступательно совершает один логический шаг за другим, пока не придет к некоторому решению.
Предложим несколько советов по организации поиска решения задачи [Косовский, Хитров]
Выразить задачу на простом, метафорическом языке. Поиск аналогий может привести к открытию новых фактов.
Фиксировать внимание к произвольным мыслям и ощущениям.
Найти язык чертежей, формул, программ, на котором удается переформулировать задачу. Возможно, при переформулировке что-то станет яснее.
Следует понять - в чем смысл вопроса. Зачем вообще решать эту задачу? Здесь уместен принцип "выковыривания изюминки" - чтобы начать выковыривать изюминку, надо сначала найти булку с изюмом.
Ждать, пока решение не придет в голову. Лишь при затянувшемся ожидании следует переходить к другим советам. Следует заметить, что особенно эффективен этот совет для ответа на следующие вопросы: "Что такое любовь?", "Что такое старость?".
Данный процесс обычно начинается с того, что у человека или небольшой группы людей возникает идея решения проблемы, которая:
приводит к ошибкам в программном продукте.
препятствует созданию или развитию программного продукта;
Этот классический процесс имеет следующие действия:
экспертиза идеи специалистами. Принятие решения о начале процесса планирования.
детальное исследование идеи. Выработка концепции. Постановка задачи. Создание "одностраничного описания проекта" и разработка его расширенной версии;
собственно возникновение и первичное исследование идеи, носящее максимально творческий и неформальный характер;