Автор работы: Пользователь скрыл имя, 13 Мая 2013 в 18:53, контрольная работа
Связность модуля (Cohesion) — это мера зависимости его частей. Связность — это внутренняя характеристика модуля. Чем выше связность модуля, тем лучше результат проектирования, тем меньше «ручек управления» на нем находится и тем проще эти «ручки».
Для измерения связности используют понятие силы связности (СС). Существует 7 типов связности:
1. Связность по совпадению (СС=0). В модуле отсутствуют явно выраженные внутренние связи.
2. Логическая связность (СС=1). Части модуля объединены по принципу функционального подобия. Например, модуль состоит из разных подпрограмм обработки ошибок. При использовании такого модуля клиент выбирает только одну из подпрограмм.
Ставропольский технологический институт сервиса(филиал)
Федерального государственного бюджетного образовательного учреждения
высшего профессионального образования
"Южно-Российский
государственный университет
Контрольная работа
По дисциплине: Стандартизация ,сертификация и контроль качества информационных систем
Тема:_________________________
Номер варианта:______________
Выполнил(а)
Студент(ка) группы________________________
______________________________
(фамилия, имя, отчество)
Проверил
преподаватель_________________
(фамилия, инициалы)
Ставрополь
201__г
Вопросы:
1. Процедура определения типа связности модулей программных средств.
2. Понятие стандартизации. Цели и задачи стандартизации.
3. Оценка надежности программы на основе модели Миллса.
1. Процедура определения
типа связности модулей
Связность модуля (Cohesion) — это мера зависимости его частей. Связность — это внутренняя характеристика модуля. Чем выше связность модуля, тем лучше результат проектирования, тем меньше «ручек управления» на нем находится и тем проще эти «ручки».
Для измерения связности
используют понятие силы
1. Связность по совпадению (СС=0). В модуле отсутствуют явно выраженные внутренние связи.
2. Логическая связность
(СС=1). Части модуля объединены
по принципу функционального
подобия. Например, модуль состоит
из разных подпрограмм
Недостатки:
- сложное сопряжение;
- большая вероятность внесения ошибок при изменении сопряжения ради одной из функций.
3. Временная связность (СС=3). Части модуля не связаны, но необходимы в один и тот же период работы системы.
Недостаток: сильная взаимная связь с другими модулями, отсюда — сильная чувствительность внесению изменений.
4. Процедурная связность (СС=5). Части модуля связаны порядком выполняемых ими действий, реализующих некоторый сценарий поведения.
5. Коммуникативная связность (СС=7). Части модуля связаны по данным (работают с одной и той же структурой данных).
6. Информационная (последовательная) связность (СС=9). Выходные данные одной части используются как входные данные в другой части модуля.
7. Функциональная связность (СС=10). Части модуля вместе реализуют одну функцию.
Отметим, что типы
связности 1,2,3 — результат неправильного
планирования архитектуры, а
^ Функциональная связность
Функционально связный модуль содержит элементы, участвующие в выполнении одной и только одной проблемной задачи. Примеры функционально связных модулей:
Вычислять синус угла;
Проверять орфографию;
Читать запись файла;
Вычислять координаты цели;
Вычислять зарплату сотрудника;
Определять место пассажира.
Каждый из этих модулей
имеет единичное назначение. Когда
клиент вызывает модуль, выполняется
только одна работа, без привлечения
внешних обработчиков. Например, модуль
Определять место пассажира
Некоторые из функционально
связных модулей очень просты
(например, Вычислять синус угла
или Читать запись файла), другие
сложны (например, Вычислять координаты
цели). Модуль Вычислять синус
угла, очевидно, реализует единичную
функцию, но как может модуль
Вычислять зарплату сотрудника
выполнять только одно
Приложения, построенные
из функционально связных
^ Информационная связность
При информационной (последовательной)
связности элементы-
Модуль Прием и проверка записи
прочитать запись из файла
проверить контрольные данные в записи
удалить контрольные поля в записи
вернуть обработанную запись
Конец модуля
В этом модуле 3 элемента.
Результаты первого элемента (прочитать
запись из файла) используются
как входные данные для
Сопровождать модули
с информационной связностью
почти так же легко, как и
функционально связные модули. Правда,
возможности повторного
^ Коммуникативная связность
При коммуникативной связности элементы-обработчики модуля используют одни и те же данные, например внешние данные. Пример коммуникативно связного модуля:
Модуль Отчет и средняя зарплата
используется Таблица зарплаты служащих
сгенерировать Отчет по зарплате
вычислить параметр Средняя зарплата
вернуть Отчет по зарплате. Средняя зарплата
Конец модуля
Здесь все элементы модуля работают со структурой Таблица зарплаты служащих.
С точки зрения клиента
проблема применения
Модули с коммуникативной
и информационной связностью
подобны в том, что содержат
элементы, связанные по данным. Их
удобно использовать, потому что
лишь немногие элементы в этих
модулях связаны с внешней
средой. Главное различие между
ними — информационно связный
модуль работает подобно
^ Процедурная связность
При достижении процедурной
связности мы попадаем в пограничную
область между хорошей
Модуль Вычисление средних значений
используется Таблица-А. Таблица-В
вычислить среднее по Таблица-А
вычислить среднее по Таблица-В
вернуть среднееТабл-А. среднееТабл-В
Конец модуля
Этот модуль вычисляет средние значения для двух полностью несвязанных таблиц Таблица-А и Таблица-В, каждая из которых имеет по 300 элементов.
^ Временная связность
При связности по времени элементы-обработчики модуля привязаны к конкретному периоду времени (из жизни программной системы).
Классическим примером временной связности является модуль инициализации:
Модуль Инициализировать Систему
перемотать магнитную ленту 1
Счетчик магнитной ленты 1 := 0
перемотать магнитную ленту 2
Счетчик магнитной ленты 2 := 0
Таблица текущих записей : = пробел..пробел
Таблица количества записей := 0..0
Переключатель 1 : = выкл
Переключатель 2 := вкл
Конец модуля
Элементы данного модуля
почти не связаны друг с
другом (за исключением того, что
должны выполняться в
Модуль со связностью
по времени испытывает те же
трудности, что и процедурно
связный модуль. Программист соблазняется
возможностью совместного
Так, при желании
инициализировать магнитную
Процедурно связные
модули и модули с временной
связностью очень похожи. Степень
их непрозрачности изменяется
от темного серого до светло-
^ Логическая связность
Элементы логически связного модуля принадлежат к действиям одной категории, и из этой категории клиент выбирает выполняемое действие. Рассмотрим следующий пример:
Модуль Пересылка сообщения
переслать по электронной почте
переслать по факсу
послать в телеконференцию
переслать по ftp-протоколу
Конец модуля
Как видим, логически
связный модуль — мешок
Действия в логически
связном модуле попадают в
одну категорию, хотя имеют
не только сходства, но и различия.
К сожалению, это заставляет
программиста «завязывать код
действий в узел»,
уродливый внешний вид с различными параметрами, обеспечивающими, например, четыре вида доступа;
запутанную внутреннюю
структуру со множеством
В итоге модуль становится сложным как для понимания, так и для сопровождения.
^ Связность по совпадению
Элементы связного по совпадению модуля вообще не имеют никаких отношений друг с другом:
Модуль Разные функции (какие-то параметры)
поздравить с Новым годом (...)
проверить исправность аппаратуры (...)
заполнить анкету героя (...)
измерить температуру (...)
вывести собаку на прогулку (...)
запастись продуктами (...)
приобрести «ягуар» (...)
Конец модуля
Связный по совпадению
модуль похож на логически
связный модуль. Его элементы-действия
не связаны ни потоком данных,
ни потоком управления. Но в
логически связном модуле
Чтобы клиент мог
воспользоваться модулем
К счастью, связность
по совпадению встречается
бездумный перевод
существующего монолитного
Информация о работе Процедура определения типа связности модулей программных средств