Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
191
Добавлен:
12.02.2016
Размер:
1.64 Mб
Скачать

Лекція 2. Елементи програмної інженерії.

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

ПП повинен бути мобільним.

Мобільність - це здатність ПЗ бути перенесеним з одного середовища (оточення) в інше, зокрема, з однієї ЕОМ на іншу.

Функціональність і надійність є обов'язковими критеріями якості ПЗ, причому забезпечення надійності буде червоною ниткою проходити по всіх етапах і процесах розробки ПЗ. Решта критеріїв використовується залежно від потреб користувачів відповідно до вимог до ПЗ - їх забезпечення обговорюватиметься у відповідних розділах курсу.

Створення ПЗ повинно вкладатися до бюджету

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

зчого найчастіше складаються витрати на створення ПЗ:

60% - розробка;

40% - тестування.

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

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

Створення ПЗ повинно вкладатися в терміни

Запорука успіху - строге дотримання наступних принципів:

Грамотне планування.

Аналіз можливих рисок і способи реагування.

Боротьба за чіткі межі проекту.

Мотивування співробітників.

3.Забезпечення надійності розробки ПЗ

Розглянемо тепер загальні принципи забезпечення надійності ПЗ, що, як ми вже підкреслювали, є основним мотивом розробки ПЗ, задаючим специфічне забарвлення всім технологічним процесам розробки ПЗ. У техніці відомо чотири підходи забезпеченню надійності:

a.попередження помилок;

b.автовизначення помилок;

c.автовиправлення помилок;

d.стійкість до помилок.

Метою підходу попередження помилок - не допустити помилок в готових продуктах, в нашому випадку - в ПЗ. Проведений розгляд природи помилок при розробці ПЗ дозволяє для досягнення цієї мети сконцентрувати увагу на наступних питаннях:

• боротьбі з складністю

• забезпеченні точності перекладу

• подолання бар'єру між користувачем і розробником

• забезпечення контролю ухвалюваних рішень.

Цей підхід пов'язаний з організацією процесів розробки ПЗ, тобто з технологією програмування. І хоча, як ми вже відзначали, гарантувати відсутність помилок в ПЗ неможливо, але в рамках цього підходу можна досягти прийнятного рівня надійності ПЗ.

Решта трьох підходу пов'язана з організацією самих продуктів технології, в нашому випадку - програм. Вони враховують можливість помилки в програмах. Самообнаруженіє помилки в програмі означає, що програма містить засоби виявлення відмови в процесі її виконання. Самоісправленіє

16

Лекція 2. Елементи програмної інженерії.

помилки в програмі означає не тільки виявлення відмови в процесі її виконання, але і виправлення наслідків цієї відмови, для чого в програмі повинні бути відповідні засоби. Забезпечення стійкості програми до помилок означає, що в програмі містяться засоби, що дозволяють локалізувати область впливу відмови програми, або зменшити його неприємні наслідки, а іноді запобігти катастрофічним наслідкам відмови. Проте, ці підходи використовуються вельми рідко (можливо, відносно частіше використовується забезпечення стійкості до помилок). Зв'язано це, по-перше, з тим, що багато простих методів, використовуваних в техніці в рамках цих підходів, непридатні в програмуванні, наприклад, дублювання окремих блоків і пристроїв (виконання двох копій однієї і тієї ж програми завжди приводитиме до однакового ефекту - правильному або неправильному). А, по-друге, додавання в програму додаткових засобів приводить до її ускладнення (іноді - значному), що в якійсь мірі заважає методам попередження помилок.

Забезпечення точності перекладу

Забезпечення точності перекладу направлене на досягнення однозначності інтерпретації документів різними розробниками, а також користувачами ПЗ. Це вимагає дотримуватися при перекладі певної дисципліни. Майерс пропонує використовувати загальну дисципліну вирішення завдань, розглядаючи переклад як рішення задачі [3.11]. Кращим керівництвом за рішенням завдань він рахує книгу Пойа "Як вирішувати задачу" [3.12]. Відповідно до цього весь процес перекладу можна розбити на наступні етапи:

Зрозуміти завдання;

Скласти план (включаючи цілі і методи рішення);

Виконатеиплан (перевіряючи правильність кожного кроку);

Проаналізувати отримане рішення.

Подолання бар'єру між користувачем і розробником

Як забезпечити, щоб ПЗ виконувала те, що користувачеві розумно чекати від неї? Для цього необхідно правильно зрозуміти, по-перше, чого хоче користувач, і, по-друге, його рівень підготовки і навколишнє його оточення. Тому слідує - привертати користувача в процеси ухвалення рішень при розробці ПЗ, - ретельно освоїти особливості його роботи (краще всього - побувати в його "шкурі").

Контроль ухвалюваних рішень

Обов'язковим кроком в кожному процесі (етапі) розробки ПЗ повинна бути перевірка правильності ухвалених рішень. Це дозволить виявляти і виправляти помилки на найранішій стадії після її виникнення, що, по-перше, істотно знижує вартість її виправлення і, по-друге, підвищує вірогідність правильного її усунення.

Зурахуванням специфіки розробки ПЗ необхідно застосовувати скрізь, де це можливо

суміжний контроль

поєднання як статичних, так і динамічних методів контролю.

Суміжний контроль означає, перевірку отриманого документа особами, що не беруть участь в його розробці, з двох сторін: по-перше, з боку автора початкового для контрольованого процесу документа, і, по-друге, особами, які використовуватимуть отриманий документ як початкового в подальших технологічних процесах. Такий контроль дозволяє забезпечувати однозначність інтерпретації отриманого документа.

Поєднання статичних і динамічних методів контролю означає, що потрібно не тільки контролювати документ як такий, але і перевіряти, який процес обробки даних він описує. Це відображає одну із специфічних особливість ПЗ (статична форма, динамічний зміст).

Програмні інженери і наукове середовище

Взаємодія з науковим середовищем - один із способів підвищення ефективності діяльності. Можлива вигода від співпраці з ученими:

Нові технології.

Нові методи, алгоритми.

17