Existuje několik osvědčených metod pro vývoj software, tzv. best practices. Volba konkretní metody závisí na specifikaci projektu, rozpočtu, subjektivní preferenci a dokonce i temperamentu vedoucího. V tomto článku krátce popíšeme základní metody vývoje webových a mobilních aplikací.
- «RAD Model» (rapid application development model nebo rychlý vývoj aplikací)
RAD model - druh inkrementálního modelu. V tomto modelu jsou komponenty nebo funkce vyvíjeny několika vysoce kvalifikovanými týmy paralelně - jako kdyby v několika mini projektech. Časové rámce jednoho cyklu jsou značně omezené. Vytvořené moduly jsou pak integrovány do jednoho pracovního prototypu.
RAD model zahrnuje následující fáze:
- Obchodní modelování
- Modelování dat
- Modelování procesů
- Sestavení aplikace
- Testování
Kdy použít RAD-model?
Může být použit pouze v přítomnosti vysoce kvalifikovaných a specializovaných architektů. Rozpočet projektu má být dostatečně velký. RAD-model může být zvolen při jisté znalosti cílového podnikání a nezbytnosti okamžité realizace systému během 2-3 měsíců.
- «Agile Model» (Agilní vývoj)
V agilním vývoji dochází k rozdělení vývoje do 1-2 týdenních etap, ve kterých se vždy hodnotí a okomentuje hotová funkcionalita a definuje se další vývoj. Zákazník tak může sledovat, zda se vývoj ubíhá požadovaným směrem a v případě potřeby jej může upravit. Nevýhodou agilního vývoje je fakt, že je velmi těžké odhadnout celkové náklady a potřebný čas pro vývoj systému.
Způsob návrhu a vývoje
- Před programováním vzniká méně detailní projekt.
- Jsou orientačně naceněny a načasovány jednotlivé moduly systému.
- Implementace začíná velmi rychle a velmi rychle je vidět a prezentována první funkcionalita systému.
- Na pravidelných schůzkách se prezentuje vytvořená funkcionalita a domlouvá další postup.
- Průběžně je porovnáván již strávený čas a původně odhadovaným časem, aby byl zákazník co nejlépe informován o vývoji průběžné i celkové náročnosti.
- První verze jsou jednoduché, ale pokrývají maximum funkcionality typu “must have”. V dalších kolech dochází k realizaci “nice to have” vlastností.
- Fakturace probíhá dle detailně vykázaného času vývojářů.
Kdy použít Agilní vývoj?
- Když se často mění potřeby uživatele nebo zákazníka.
- Na rozdíl od modelu vodopádu, pro zahájení projektu v agilním modelu není potřeba detailního projektu.
- «Iterative Model» (Iterativní model)
Vývoj prostřednictvím Iterativního modelu nevyžaduje na začátku detailní zpracování projektu. Místo to se na začátku vytvoří základní verze, která tvoří základ pro budoucí požadavky. Tento proces se opakuje. Tato verze může být neideální, hlavní je, aby fungovala. Po pochopení konečného cíle se vývojáři snaží, aby byl každý jejich krok produktivní a každá verze byla funkční.
Kdy použít iterativní model?
- Požadavky k cílovému systému je předem jasně definovaný a srozumitelný.
- Projekt je velký nebo velmi rozsáhlý.
- Hlavní úkol by měl být stanoven, ale jednotlivé detaily se mohou vyvíjet v průběhu času.
- «Spiral Model» (spirálový model)
Spirálový model se podobá inkrementalnímu modelu, ale s důrazem na analýzu rizik. Funguje dobře pro řešení kriticky důležitých obchodních úkolů, kdy neúspěch je neslučitelný s činností společnosti, například v rámci výroby nových produktových řad, v případě potřeby výzkumu a praktického testování.
Spirálový model zahrnuje 4 kroky pro každé kolo:
- Plánování,
- Analýza rizik,
- Výstavba,
- Hodnocení výsledků a při uspokojivé kvalitě přechod k novému kolu.
Tento model není vhodný pro malé projekty, je vhodný pouze pro složitější a dražší projekty.
V moderní praxi je více možných modelů pro vývoj software. Neexistuje jediný správný model pro všechny projekty. I tak oblíbený agilní vývoj nejde použít všude kvůli nepřipravenosti některých zákazníků nebo nemožnosti flexibilního financování. Metodiky se částečně překrývají v nástrojích pro vývoj a jsou vzájemně podobné. V iQuestu tvoříme systémy buď na základě metody Vodopádu, kdy předem známe veškeré požadavky nebo formou Agilního vývoje, kdy zákazník upravuje zadání v průběhu prací.
Komentáře
Okomentovat