1.2. Інженерія програмного забезпечення - інженерна галузь
Інженерна галузь характеризується діяльністю, що ґрунтується на таких принципах:
- ефективність - результати отримують за допомогою заданих ресурсів, які відповідають висунутим вимогам і стандартам;
- практичність - результати мають конкретних замовників;
- фундаментальність - результати отримують на основі знань фундаментальних наук;
- успадкованість - результати отримують на основі нагромадженого досвіду, виключаючи діяльність «з нуля»;
- відчутність - результати є відчутними продуктами, які можна застосовувати, руйнувати, а також досліджувати за допомогою емпіричних методів пізнання;
- супроводження - результати, знаходячись в експлуатації, обов'язково супроводжуються (обслуговуються),
У процесі розвитку людства з'явилося багато інженерних галузей, але їх становлення проходило один і той же шлях, у якому розрізняють три фази (рис. 1.1),
Рис. 1.1. Фази розвитку інженерної галузі
У кожній фазі мають місце виконавці, ресурси, методи реалізації і використання продуктів галузі. Для фаз характерне:
- фаза І: виконавці - віртуози і талановиті одинаки; ресурси - інтуїція і груба сила; методи - випадкова передача досвіду, екстравагантне застосування матеріалі»; використання - виробництво для себе;
- фаза II: виконавці - майстерні-виробники; ресурси - окремі інструменти; методи - механічний тренінг, облік економічних чинників у виборі матеріалів; використання - виробництво для продажу, утворення ринку;
- фаза III: виконавці - досвідчені професіонали; ресурси - машини і комплекси, що використовуються в технологіях; методи - теоретичні і емпіричні, передавання знані, шляхом диференційованого навчання, супровід; використання - сегментація ринку.
Для інженерії програмного забезпечення характеристика зазначених фаз наводиться в табл. 1.2.
Інженерна діяльність реалізується інженерами в Контексті технологій. Технологія - це організована сукупність процесів, спрямованих на отримання з початкових матеріалів кінцевих продуктів за допомогою методів і засобів технологій. Інженери - це професіонали, чия освіта дозволяє їм, використовуючи знання фундаментальних наук і конкретних технологій, реалізовувати процеси, застосовуючи методи і засоби технологій для створення надійних, широко використовуваних продуктів.
Таблиця 1.2
Аспекти розглядання Фаза (початок) І II III (1980) (1960) (1970) Особливості програмування Програмування «абияк» Програмування «в малому» Програмування
«у великому» Підготовка кадрів Майже відсутня Прикладна математика Комп'ютерні науки Ресурси Асемблери, машинні дампи Транслятори, лінкери, завантажувачі, системи програмування Середовища розробки програм Відсутні НІРО, формалізовані технічні завдання R
-Технологія
, PSL/PSA, SREM, SADT Економіко Відсутня Інтуїтивна
PRICE-S, SCEP, SLIM Ринок Відсутній, замовлення на програмне забезпечення Виробництво для продажу Сегментація ринку
Нині інженерія програмного забезпечення - це систематизований, регламентований і кількісний (інженерний) підхід до вирішення завдань розробки, експлуатації, супроводу й утилізації програмного забезпечення. До того ж, процеси і програмне забезпечення мають відповідати заданим технічним, економічним, соціальним і правовим вимогам.
Технічні вимоги обов'язково відображають відповідність процесів і продуктів життєвого циклу вимогам, специфікованим замовником.
Економічні вимоги обов'язково містять вимоги щодо виконання проекту в рамках заданого фінансового бюджету.
Соціальні вимоги обов'язково відображають те, що створювані Програмні продукти повинні мати властивості корисності.
Правові вимоги обов'язково відображають те, що виконання програмного проекту повинне здійснюватися законними методами. Особливо це важливо, коли під час розробки застосовується успадковане програмне забезпечення або компоненти багаторазового використання.
Як і інші інженерні дисципліни, інженерія програмного забезпечення характеризується такими аспектами:
- творчість - інженерія концентрується на проблемах аналізу і проектування;
- інструментальність ключові проблеми в інженерії - це ви бір і використання інструментів;
- стандартизація - кращі практичні досягнення інженерії у вигляді інженерних принципів є основою створення стандартів;
- успадкованість (повторне використання) - в інженерії повтор не використання знань і продуктів фаз життєвого циклу с найважливішим чинником підвищення продуктивності і якості;
- професіоналізм - інженерія програмного забезпечення - це професія.
Остання властивість характеризує інженерію програмного забезпечення не як академічну, а швидше як практичну дисципліну. Професійний інженер з програмного забезпечення мас такі риси:
- ухвалює рішення, оцінюючи стан і кожного разу вибираючи підходи для вирішення конкретних завдань і в конкретному контексти знаходячи баланс між витратами і прибутком;
- вимірює, калібрує і оцінює вимірювальні інструменти;
- виконує в практичній діяльності одну з багатьох ролей, на приклад, дослідник, розробник, архітектор, виробник, тестер, експлуатаційник, керівник, продавець, консультант, викладач;
- результати праці інженера можуть бути різні, від пристроїв і систем, до процесів і структур;
- застосовує знання з інших дисциплін (на додаток до своїх власних), наприклад, з математики, базових наук і економіки. При цьому; основними дисциплінами є «Комп'ютерні науки», «Дискретна математика» і «Групова динаміка». Дисципліни «Фізика» і «Без перервна математика» використовуються в деяких застосуваннях, але вони менш важливі, ніж вказані;
- створює: інструменти;
- працює дисциплінованим і систематичним чином;
- працює в колективах разом з іншими фахівцями, розвиваючи навички взаємин колективної роботи;
- дотримується стичних і професійних принципів, захищаючи суспільство, замовників і себе;
- постійно поповнює свої знання, освоюючи нові методи, техніку і технології;
- спирається на специфічні знання і досвід, працюючи всередині специфічних доменів, враховуючи особливість доменних рішень, виробництва, матеріалів, вимог;
- уміє визначати, які частини можна повторно використовувати, а які слід розробляти заново.
Розділ 2. КУЛЬТУРНИЙ АСПЕКТ ІНЖЕНЕРІЇ ПРОГРАМНОГО ЗАБЕЗПЕЧЕННЯ
Культура - безліч цінностей, цілей і принципів, які керують діями, пріоритетами і рішеннями окремих осіб або групи, що працюють у напрямі спільної мети. Культура групи розробників програмного продукту дуже сильно впливає на якість продукту, продуктивність розробників і мікроклімату в групі.
2.1. Культура інженерії програмного забезпечення
Культура інженерії програмного забезпечення - це сукупність позицій розробників, людських відносин і технічних процесів, орієнтованих на якість у широкому сенсі. Кожна організація і особа має власну культуру, набуту шляхом копіткої роботи. Культура інженерії програмного забезпечення характеризується такими чинниками:
- чіткими організаційними цілями;
- зобов'язанням менеджменту вести організацію до досягнення встановлених цілей;
- середовищем, яке дає змогу кожному розробникові вдосконалювати і ефективно застосовувати свої знання і навички;
- вимірюваннями, що дають змогу добирати ефективні процеси. Будь-яка «здорова» культура повинна містити три істотні компоненти:
- персональне зобов'язання кожного розробника створювати якісні продукти шляхом систематичного застосування передового досвіду інженерії програмного забезпечення;
- зобов'язання менеджерів усіх, рівнів забезпечувати середовище, в якому якість програмного забезпечення (у всіх його аспектах) є фундаментальною концепцією і кожен розробник може реалізовувати цю концепцію;
- зобов'язаній всіх членів організації постійно вдосконалювати процеси, в яких воли беруть участь і продукти, які вони створюють.