Автор работы: Пользователь скрыл имя, 12 Ноября 2013 в 16:05, курсовая работа
Компьютер без программного обеспечения - груда металла, которую к тому же нельзя сдать на металлолом. Купив даже самый быстродействующий компьютер, предприятие не решает основной проблемы - автоматизация предприятия. Для этого нужны программы. Разнообразие программного обеспечения куда больше, чем технических решений. Так как они решают самые различные задачи, начиная от связи с оборудованием (драйвера) и заканчивая автоматизацией бухгалтерского учета или 3-х мерными играми. Однако даже при таком большом разнообразии программных решений может оказаться, что нет полностью удовлетворяющего программного решения.
ВВЕДЕНИЕ 3
Определение и этапы реинжиниринга 5
Цели и задачи реинжиниринга 8
Проблемы при реинжиниринге 9
Управление требованиями 9
Реинжиниринг программного обеспечения 11
Почему компании-разработчики не любят реинжиниринг 13
ЗАКЛЮЧЕНИЕ 14
СПИСОК ИСПОЛЬЗУЕМОЙ ЛИТЕРАТУРЫ 16
СОДЕРЖАНИЕ
ВВЕДЕНИЕ
Определение и этапы реинжиниринга
Цели и задачи реинжиниринга
Проблемы при реинжиниринге
Управление требованиями
Реинжиниринг программного
обеспечения
Почему компании-разработчики
не любят реинжиниринг
ЗАКЛЮЧЕНИЕ
СПИСОК ИСПОЛЬЗУЕМОЙ ЛИТЕРАТУРЫ
Введение
Компьютер без программного обеспечения - груда металла, которую к тому же нельзя сдать на металлолом. Купив даже самый быстродействующий компьютер, предприятие не решает основной проблемы - автоматизация предприятия. Для этого нужны программы. Разнообразие программного обеспечения куда больше, чем технических решений. Так как они решают самые различные задачи, начиная от связи с оборудованием (драйвера) и заканчивая автоматизацией бухгалтерского учета или 3-х мерными играми. Однако даже при таком большом разнообразии программных решений может оказаться, что нет полностью удовлетворяющего программного решения.
Для решения данной проблемы
предприятие, как правило, находит
программиста, который пытается реализовать
данную программу. Проходит время, программа
внедряется на предприятии и с
ней начинает работать большое количество
персонала. Привыкнув к программе,
сотрудники уже не представляют себя
без столь удобного инструмента,
как программа. Проходит еще время,
а программист берет и
Вот, почему, предприятия, которые
работают долго и успешно на рынке,
в результате приходят к выводу,
что для дальнейшего
Определение и этапы реинжиниринга
Реинжиниринг программного обеспечения — процесс создания новой функциональности или устранения ошибок, путём революционного изменения, но используя уже имеющееся в эксплуатации программное обеспечение. Процесс реинжиниринга описан Chikofsky и Кроссом в их труде 1990 года, как «The examination and alteration of a system to reconstitute it in a new form». Выражаясь менее формально, реинжиниринг является изменением системы программного обеспечения после проведения обратного инжиниринга. Реинжиниринг программного обеспечения, можно разделить на несколько этапов: Начальная фаза. Начать процесс реинжиниринга следует с определения того, что есть по существующей системе (исходные тесты, БД, описания и т. д.). При этом фиксируется текущее состояние наследуемой системы (все изменения, вносимые в нее после этого момента, при выполнении реинжиниринга не учитываются). Если есть возможность выполняется развертывание наследуемой ПС у разработчика.
Определение системных архитектур.
Работы по описанию архитектур начинаются
фактически на начальном этапе, когда
определяется состав оборудования и
стандартное программное
Автоматический реинжиниринг бизнес логики может быть выполнен только в случае, когда имеются (полностью или частично) исходные тексты программ. В результате автоматического реинжиниринга кодов создаются диаграммы классов и диаграммы компонент UML.
Реинжиниринг БД выполняется с помощью инструментальных средств проектирования БД. Результатом является реляционная модель данных, которая может графически отображаться этим средством. Полученная реляционная модель может по усмотрению разработчиков переведена в диаграмму классов UML путем использования применяемого инструментального средства разработки БД или программных мостов со средствами визуального ОО моделирования. Редактирование диаграмм моделей. Модели, полученные автоматически, весьма сложно читать и анализировать, поскольку элементы модели размещаются без учета наглядности диаграмм. Поэтому построенные модели должны быть отредактированы. В процессе редактирования не следует выполнять содержательные преобразования (удалять или добавлять элементы модели). Главной целью редактирования на этом этапе является достижение наглядности диаграмм. Для этого используется перемещение элементов диаграмм. В процессе редактирования могут вноситься комментарии к элементам модели. Например, можно прокомментировать назначение отдельных классов. Комментарии заносятся в поля спецификаций элементов моделей.
Если диаграмма содержит слишком много элементов, то анализировать ее сложно. Попробуйте проанализировать диаграмму, содержащую более 100 классов! Поэтому целесообразно разбить такую диаграмму на несколько отдельных диаграмм, оставляя в каждой примерно по 7 – 10 элементов.
Метод повышения наглядности диаграмм хорошо известен. Это иерархическая реструктуризация. Средством ее осуществления в UML являются пакеты. Сложные ПС обычно включают несколько подсистем, имеющих разное целевое назначение и функциональность. Поэтому на верхнем уровне иерархии можно показать пакеты – подсистемы. Каждый из таких пакетов должен получить имя, отражающее суть соответствующей подсистемы. На этом уровне можно также показать пакеты классов, являющиеся общими для всей системы и используемые подсистемами. На начальной стадии реструктуризации логической модели можно ввести пакет верхнего уровня, куда помещаются классы, которые трудно отнести к какому-либо другому пакету. В любой ПС есть пользовательский интерфейс, связь с БД, управление, обработка, классы данных. Такого типа пакеты можно ввести в каждой подсистеме на следующем уровне иерархии. Построение функциональной модели. Модель функционирования описывается с помощью диаграмм ВИ и детализирующих их диаграмм последовательностей и деятельностей. Источником для ее построения является работающая наследуемая система и проводимые с ней эксперименты. На этом этапе особенно эффективно привлечение к работам по реинжинирингу эксперта организации заказчика. С его помощью можно быстрее и точнее определить состав актеров наследуемой системы и основные ВИ. Эксперт заказчика может словесно описать, кто использует систему и что она должна делать для пользователей каждого типа. Он может также информировать, с какими другими системами взаимодействует наследуемая ПС, какие работы осуществляются периодически. Все эти сведения будут способствовать более точному пониманию функциональности системы разработчиками.
Определение вариантов использования.
Определение ВИ выполняется на основе
анализа экранов работающей системы.
Сначала определяются пакеты ВИ. Для
этого следует найти все
если основной экран – форма, то это отдельный ВИ.
Цели и задачи реинжиниринга
Цели проведения реинжиниринга заключаются в следующем:
получение представления о составе существующей системы;
моделирование существующей системы;
определение фрагментов программного
кода, которые могут быть использованы
в разрабатываемой новой
определение наследуемых данных.
Задачи реинжиниринга
Задачи, решаемые при реинжиниринге, включают:
определение системных архитектур;
определение актеров существующей системы;
определение функциональности существующей системы;
определение логической структуры системы;
восстановление реляционной модели данных.
Порядок решения этих задач
принципиально отличается от порядка
действий, выполняемых при разработке
новых проектов. Логическая архитектура
системы определена ее реализацией,
в частности, структурой каталогов,
размещением файлов по каталогам, распределением
задач между сервером и клиентскими
местами. Кроме того, часть моделей
системы может быть получена автоматически
с помощью инструментальных средств.
Таким образом, не функциональное описание
системы служит основой для выявления
классов и отношений между
ними, а наоборот, предварительно полученные
диаграммы классов могут
Проблемы при реинжиниринге
Как правило утверждается, что "легче разработать новый программный продукт". Это связано со следующими проблемами:
Обычному программисту сложно разобраться в чужом исходном коде. Реинжиниринг чаще всего дороже разработки нового программного обеспечения, т.к. требуется убрать ограничения предыдущих версий, но при этом оставить совместимость с предыдущими версиями.
Реинжиниринг не может
сделать программист низкой и
средней квалификации. Даже профессионалы
часто не могут качественно реализовать
его. Поэтому требуется работа программистов
с большим опытом переделки программ
и знанием различных
Управление требованиями
Требования к ПС
Требование – это
Функциональные требования
определяют действия, которые должна
выполнять ПС, без учета физических
ограничений. Тем самым они определяют
поведение системы при вводе
и выводе. Процесс выявления
таких требований к системе обычно много,
заказчик не всегда способен четко сформулировать, чего он хочет от системы,
требования в итоговом документе должны быть изложены так, чтобы они одинаково понимались заказчиком и исполнителем и не допускали неоднозначности,
между функциональными требованиями могут быть разные зависимости, усложняющие управление ими в случае необходимости внесения изменений.
Для преодоления этих трудностей
применяется моделирование
Нефункциональные требования
не описывают поведение
Управление требованиями
– это достаточно сложный и
растянутый во времени процесс. Он продолжается
в течение большей части
неочевидны,
исходят из многих источников,
трудно формулируются (язык неоднозначен),
состоят из множества различных деталей,
неравнозначны,
связаны друг с другом,
лежат не только в функциональной области.
могут изменяться в течение разработки и при сопровождении.
Реинжиниринг программного обеспечения
Определение потенциальной архитектуры. Данная деятельность включает архитектурный анализ и анализ ВИ. Определяется первоначальный набор архитектурно значимых элементов и механизмов реализации, выполняется начальное разбиение на уровни, определяется структура системы, выбираются ВИ, которые будут реализовываться в первой итерации фазы развития проекта. В результате создается эскиз архитектуры ПС. На основе анализа архитектурно значимых ВИ определяются основные классы, которые включаются в модель анализа. В модель анализа включаются диаграммы, описывающие взаимодействие основных классов.