- •Конструювання програмного забезпечення (Software Construction по swebok)
- •1. Основи конструювання (Software Construction Fundamentals)
- •1.1 Мінімізація складності (Minimizing Complexity)
- •1.2 Очікування змін (Anticipating Changes)
- •1.4 Стандарти в конструюванні (Standards in Constructing)
- •2. Управління конструюванням (Managing Construction)
- •2.1 Моделі конструювання (Construction Models)
- •2.2 Планування конструювання (Construction Planning)
- •2.3 Вимірювання в конструюванні (Construction Measurement)
- •3. Практичні міркування (Practical Considerations)
- •3.2 Мови конструювання (Construction Languages)
- •3.3 Кодування (Coding)
- •3.4 Тестування в конструюванні (Construction Testing)
- •3.5 Повторне використання (Reuse)
- •3.6 Якість конструювання (Construction Quality)
- •3.7 Інтеграція (Integration)
1. Основи конструювання (Software Construction Fundamentals)
Фундаментальні основи конструювання програмного забезпечення включають: • Мінімізація складності
• Очікування змін
• Конструювання з можливістю перевірки
• Стандарти у конструюванні
Перші три концепції застосовуються не тільки до конструювання, але і проектування, і лежать в основі сучасних методологій управління життєвим циклом програмних систем.
1.1 Мінімізація складності (Minimizing Complexity)
Основною причиною того, чому люди використовують комп'ютери в бізнес-цілях, є обмежені можливості людей в обробці і зберіганні складних структур і великих обсягів інформації, зокрема, протягом тривалого періоду часу. Це міркування є однією з основних рушійних сил в конструюванні програмного забезпечення: мінімізація складності. Потреба у зменшенні складності впливає на всі аспекти конструювання і особливо критична для процесів верифікації (перевірки) та тестування результатів конструювання, тобто самих програмних систем.
Зменшення складності у конструюванні програмного забезпечення досягається при приділення особливої уваги створенню простого і легко читається коду, нехай і на шкоду прагненню зробити його ідеальним (наприклад, з точки зору гнучкості або проходження тих чи інших уявленням про красу, витонченості коду, спритності тих чи інших прийомів, що дозволяють його скоротити на шкоду розмірами і т.п.). Це не означає, що повинно обмежуватися застосування тих чи інших розвинених мовних можливостей використовуваних засобів програмування. Це передбачає "лише" надання більшої значущості читаності коду, простоті тестування, прийнятного рівня продуктивності та задоволенню заданих критеріїв, замість постійного вдосконалення коду, не оглядаючись на терміни, функціональність та інші характеристики та обмеження проекту. Мінімізація складності досягається, зокрема, проходженням стандартам (обговорюються в темі 1.4 "Стандарти у конструюванні"), використанням низки специфічних технік (висвітлюються в 3.3 "Кодування") і підтримкою практик, спрямованих на забезпечення якості в конструюванні (3.5 "Якість конструювання") .
1.2 Очікування змін (Anticipating Changes)
Більшість програмних систем змінюються з часом. Причин цьому - безліч. Очікування змін є однією з рушійних сил конструювання програмного забезпечення. Програмне забезпечення не є ізольованим від зовнішнього оточення (як системного, так і з точки зору галузі діяльності, для автоматизації завдань і проблем якого воно застосовується). Більше того, програмні системи є частиною змінюється середовища і повинні змінюватися разом з нею, а, іноді, і бути джерелом змін самого середовища.
Очікування змін підтримується рядом технік, представлених в темі 3.3 "Кодування". 1.3 Конструювання з можливістю перевірки (Constructing for Verification)
"Конструювання для перевірки" (а саме такий сенс закладений в оригінальна назва даної теми) припускає, що побудова програмних систем повинно вестися таким чином, щоб сама програмна система допомагала вести пошук причин збоїв, будучи прозорою для застосування різних методів перевірки (і, до речі, внесення необхідних змін), як на стадії незалежного тестування (наприклад, інженерами-тестувальниками), так і в процесі операційної діяльності - експлуатації, коли особливо важлива можливість швидкого виявлення та виправлення виникаючих помилок. Серед технік, спрямованих на досягнення такого результату конструювання: • огляд, оцінка коду (code review)
• модульне тестування (unit-testing)
• структурування коду для і спільно з застосуванням автоматизованих засобів тестування (automated testing)
• обмежене застосування складних або важких для розуміння мовних структур
