Jackson strukturované programování - Jackson structured programming
Jackson strukturované programování (JSP) je metoda pro strukturované programování vyvinutý britským softwarovým konzultantem Michael A. Jackson a popsáno v jeho knize z roku 1975 Zásady návrhu programu.[1] Technika JSP je analyzovat datové struktury souborů, které musí program číst jako vstup a produkovat jako výstup, a poté vytvořit návrh programu založený na těchto datových strukturách, takže řídicí struktura programu zpracovává tyto datové struktury v přirozeném a intuitivní způsob.
JSP popisuje struktury (dat i programů) pomocí tří základních struktur - sekvence, iterace a výběru (nebo alternativ). Tyto struktury jsou zobrazeny jako (ve skutečnosti) vizuální reprezentace a regulární výraz.
Úvod
Michael A. Jackson původně vyvinut JSP v 70. letech. Systém zdokumentoval ve své knize z roku 1975 Zásady návrhu programu.[1] V konferenčním rozhovoru z roku 2001[2] poskytl retrospektivní analýzu původních hnacích sil za touto metodou a dal ji do souvislosti s následným vývojem softwarového inženýrství. Jacksonovým cílem bylo udělat COBOL programy pro dávkové zpracování souborů se snadněji upravují a udržují, ale tuto metodu lze použít k navrhování programů pro všechny programovací jazyk který má strukturované řídící konstrukty - sekvenci, iteraci a výběr („if / then / else“).
Jackson strukturované programování bylo podobné Warnier / Orr strukturované programování[3][4] ačkoli JSP zvažoval jak vstupní, tak výstupní datové struktury, zatímco metoda Warnier / Orr se zaměřovala téměř výlučně na strukturu výstupního proudu.
Motivace metody
V době vývoje JSP byla většina programů dávkové programy COBOL, které zpracovávaly sekvenční soubory uložené na pásku. Typický program čte vstupní soubor jako posloupnost záznamů, takže všechny programy mají stejnou strukturu - jednu hlavní smyčku, která zpracovává všechny záznamy v souboru, jeden po druhém. Jackson tvrdil, že tato programová struktura byla téměř vždy špatná, a vyzval programátory, aby hledali složitější datové struktury. V kapitole 3 Zásady návrhu programu[1] Jackson představuje dvě verze programu, jednu navrženou pomocí JSP, druhou využívající tradiční strukturu s jednou smyčkou. Zde je jeho příklad přeložený z COBOLu do Javy. Účelem těchto dvou programů je rozpoznat skupiny opakovaných záznamů (řádků) v seřazeném souboru a vytvořit výstupní soubor s výpisem každého záznamu a počtem výskytů v souboru.
Zde je tradiční verze programu s jednou smyčkou.
Tětiva čára;int počet = 0;Tětiva firstLineOfGroup = nula;// začíná jedna hlavní smyčkazatímco ((čára = v.readLine()) != nula) { -li (firstLineOfGroup == nula || !čára.rovná se(firstLineOfGroup)) { -li (firstLineOfGroup != nula) { Systém.ven.tisk(firstLineOfGroup + " " + počet); } počet = 0; firstLineOfGroup = čára; } počet++;}-li (firstLineOfGroup != nula) { Systém.ven.tisk(firstLineOfGroup + " " + počet);}
Tady je verze stejného programu ve stylu JSP. Všimněte si, že (na rozdíl od tradičního programu) má dvě smyčky, jednu vnořenou do druhé. Vnější smyčka zpracovává skupiny opakujících se záznamů, zatímco vnitřní smyčka zpracovává jednotlivé záznamy ve skupině.
Tětiva čára;int numberOfLinesInGroup;čára = v.readLine();// zahájit vnější smyčku: zpracovat 1 skupinuzatímco (čára != nula) { numberOfLinesInGroup = 0; Tětiva firstLineOfGroup = čára; // začátek vnitřní smyčky: zpracování 1 záznamu ve skupině zatímco (čára != nula && čára.rovná se(firstLineOfGroup)) { numberOfLinesInGroup++; čára = v.readLine(); } Systém.ven.tisk(firstLineOfGroup + " " + numberOfLinesInGroup);}
Jackson kritizuje tradiční single-loop verzi za to, že nezpracoval strukturu vstupního souboru (opakující se skupiny záznamů obsahující opakující se jednotlivé záznamy) přirozeným způsobem. Jedním z příznaků jeho nepřirozeného designu je, že aby správně fungoval, je nucen zahrnout speciální kód pro zpracování prvního a posledního záznamu souboru.
Základní metoda
JSP používá semi-formální kroky k zachycení stávající struktury vstupů a výstupů programu ve struktuře samotného programu.
Záměrem je vytvořit programy, které lze snadno upravovat po celou dobu jejich životnosti. Jacksonovým hlavním poznatkem bylo, že změny požadavků jsou obvykle drobnými vylepšeními stávajících struktur. U programu vytvořeného pomocí JSP se všechny vstupy, výstupy a vnitřní struktury programu shodují, takže malé změny vstupů a výstupů by se měly promítnout do malých změn programu.
JSP strukturuje programy z hlediska čtyř typů komponent:
- základní operace
- sekvence
- iterace
- výběry
Metoda začíná popisem vstupů programu z hlediska čtyř základních typů komponent. Dále pokračuje stejným způsobem výstupy programu. Každý vstup a výstup je modelován jako samostatný Schéma datové struktury (DSD). Aby JSP fungovalo pro aplikace náročné na výpočetní techniku, jako je digitální zpracování signálu (DSP), je také nutné nakreslit diagramy struktury algoritmu, které se zaměřují spíše na vnitřní datové struktury než na vstupní a výstupní.
Vstupní a výstupní struktury jsou poté sjednoceny nebo sloučeny do konečné programové struktury, známé jako Diagram struktury programu (PSD). Tento krok může zahrnovat přidání malého množství řídicí struktury na vysoké úrovni, aby se spojily vstupy a výstupy. Některé programy zpracovávají veškerý vstup před provedením jakéhokoli výstupu, zatímco jiné čtou v jednom záznamu, zapisují jeden záznam a iterují. Tyto přístupy musí být zachyceny v PSD.
Jazyk PSD, který je jazykově neutrální, je poté implementován v programovacím jazyce. JSP je zaměřen na programování na úrovni řídicích struktur, takže implementované návrhy používají pouze primitivní operace, sekvence, iterace a výběry. JSP se nepoužívá ke strukturování programů na úrovni tříd a objektů, i když může pomoci strukturovat regulační tok v rámci metod třídy.
JSP používá diagramovou notaci k popisu struktury vstupů, výstupů a programů s prvky diagramu pro každý ze základních typů komponent.
Jednoduchá operace je nakreslena jako rámeček.
Operace
Posloupnost operací je představována boxy spojenými s linkami. V níže uvedeném příkladu se operace A skládá ze sledu operací B, C a D.
Sekvence
Iterace je opět znázorněna spojenými rámečky. Iterovaná operace má navíc hvězdu v pravém horním rohu pole. V níže uvedeném příkladu operace A sestává z iterace nulové nebo více vyvolání operace B.
Iterace
Výběr je podobný posloupnosti, ale s kruhem nakresleným v pravém horním rohu každé volitelné operace. V příkladu se operace A skládá z jedné a pouze jedné z operací B, C nebo D.
Výběr
Fungující příklad
Jako příklad lze uvést, jak by programátor JSP navrhoval a kódoval a kodér délky běhu. Kodér délky běhu je program, jehož vstupem je proud bajtů, které lze zobrazit jako vyskytující se v běží, kde běh se skládá z jednoho nebo více výskytů bajtů stejné hodnoty. Výstupem programu je proud bajtových párů, kde každý bajtový pár je komprimovaným popisem běhu. V každé dvojici je první bajt hodnotou opakovaného bajtu v běhu a druhým bajtem je číslo označující počet opakování dané hodnoty v běhu. Například běh osmi výskytů písmene „A“ ve vstupním proudu („AAAAAAAAA“) by ve výstupním proudu vyprodukoval „A8“ jako bajtový pár. Kodéry délky běhu se často používají pro hrubou kompresi bitmap.
U JSP je prvním krokem popis datových struktur vstupních toků programu. Program má pouze jeden vstupní proud, který se skládá z nuly nebo více běží stejné bajtové hodnoty. Zde je diagram datové struktury JSP pro vstupní proud.
Druhým krokem je popis struktury výstupních dat, která v tomto případě sestává z nulové nebo více iterací bajtových párů.
Dalším krokem je popis korespondence mezi složkami vstupní a výstupní struktury.
Dalším krokem je použití korespondence mezi těmito dvěma datovými strukturami k vytvoření programové struktury, která je schopna zpracovávat strukturu vstupních dat a vytvářet strukturu výstupních dat. (Někdy to není možné. Viz diskuse o střety struktur, níže.)
Jakmile je struktura programu dokončena, programátor vytvoří seznam výpočetních operací, které musí program provést, a schéma struktury programu se zhmotní zavěšením těchto operací na příslušné konstrukční součásti.
- přečíst bajt
- pamatovat bajt
- nastavit čítač na nulu
- čítač přírůstků
- výstup zapamatovaný bajt
- čítač výstupu
V této fázi jsou také uvedeny podmínky pro iterace (smyčky) a výběry (příkazy if-then-else nebo case) a přidány do diagramu struktury programu.
- zatímco existuje více bajtů
- zatímco existuje více bajtů a tento bajt je stejný jako první bajt běhu a počet se stále vejde do bajtu
Jakmile je diagram hotový, lze jej přeložit do libovolného používaného programovacího jazyka. Zde je překlad do C.
#zahrnout <stdio.h>#zahrnout <stdlib.h>int hlavní(int argc, char *argv[]){ int C; int first_byte; int počet; C = getchar(); / * získejte první bajt * / zatímco (C != EOF) { / * zpracuje první bajt v běhu * / first_byte = C; počet = 1; C = getchar(); / * získat další bajt * / / * zpracovat následující bajty v běhu * / zatímco (C != EOF && C == first_byte && počet < 255) { / * zpracovat jeden bajt stejné hodnoty * / počet++; C = getchar(); / * získat další bajt * / } putchar(first_byte); putchar(počet); } vrátit se EXIT_SUCCESS;}
Techniky řešení obtížných konstrukčních problémů
v Zásady návrhu programu Jackson rozpoznal situace, které představovaly konkrétní druhy konstrukčních problémů, a poskytl techniky jejich řešení.
Jednou z těchto situací je případ, kdy program zpracuje dva vstupní soubory, nikoli jeden. V roce 1975 bylo jedním ze standardních „zlých problémů“ návrh programu zpracování transakcí. V takovém programu je spuštěn sekvenční soubor aktualizačních záznamů proti sekvenčnímu hlavnímu souboru, který jako výstup vytváří aktualizovaný hlavní soubor. (Například v noci by banka spustila dávkový program, který by aktualizoval zůstatky na účtech svých zákazníků na základě záznamů o vkladech a výběrech, které ten den provedly.) Zásady návrhu programu poskytl standardní řešení tohoto problému spolu s vysvětlením logiky pozadí návrhu.
Další druh problému zahrnoval to, co Jackson nazýval „problémy s rozpoznáním“, a dnes bychom jej nazvali problémy s analýzou. Základní technika návrhu JSP byla doplněna operacemi POSIT a QUIT, aby bylo možné navrhnout to, co bychom nyní nazvali analyzátor zpětného sledování.
JSP také rozpoznala tři situace, které se nazývají „střety struktur“ - střet hranic, střet objednávek a střet prokládání - a poskytla techniky jejich řešení. V situacích střetu struktury jsou vstupní a výstupní datové struktury tak nekompatibilní, že ze vstupního souboru není možné vytvořit výstupní soubor. Ve skutečnosti je nutné napsat dva programy - první zpracuje vstupní proud, rozdělí ho na menší bloky a zapíše tyto bloky do mezilehlého souboru. Druhý program načte mezilehlý soubor a vytvoří požadovaný výstup.
JSP a objektově orientovaný design
JSP byl vyvinut dlouho předtím, než byly k dispozici objektově orientované technologie. To a jeho nástupnická metoda JSD nezacházejte s tím, co se nyní bude nazývat „objekty“, jako s kolekcemi víceméně nezávislých metod. Místo toho, po práci C A R Hoare „JSP a JSD popisují softwarové objekty jako společné rutiny.[5][6]
Viz také
Reference
- ^ A b C Jackson, MA (1975), Zásady návrhu programu, Academic.
- ^ Jackson, MA (2001), Perspektiva JSP (PDF), sd & m Pioneers 'Conference, Bonn, červen 2001, vyvoláno 2017-01-26CS1 maint: umístění (odkaz)
- ^ Warnier, JD (1974), Logická konstrukce programů, NY: Van Nostrand Reinhold
- ^ Orr, KT (1980), „Strukturované programování v 80. letech“, Sborník z výroční konference ACM 1980, New York, NY: ACM Press, s. 323–26, doi:10.1145/800176.809987, ISBN 978-0897910286
- ^ Wieringa, R (prosinec 1998), „Průzkum strukturovaných a objektově orientovaných metod a technik specifikací softwaru“, Comput Surv, 30 (4): 459–527, CiteSeerX 10.1.1.107.5410, doi:10.1145/299917.299919.
- ^ Henderson-Sellers, Brian; Edwards, JM (září 1990), „Životní cyklus objektově orientovaných systémů“, Komunikace ACM, 33 (9): 142–59, doi:10.1145/83880.84529.