Pascal | |
---|---|
Jazyková třída | imperativ , strukturovaný |
Typ provedení | sestaven |
Objevil se v | 1970 |
Autor | Niklaus Wirth |
Přípona souboru | .paspro soubory kódu, .incpro soubory záhlaví . |
Uvolnění | ISO/IEC 10206:1991 Fáze: 90,93 ( 29. července 2008 ) |
Typový systém | statický , silný , bezpečný [1] |
Hlavní implementace | CDC 6000 , ICT 1900 , Pascal-P , PDP-11 , PDP-10 , IBM System/370 , HP , Free Pascal , GNU , PascalABC.NET |
Dialekty | UCSD , Turbo , Delphi |
Byl ovlivněn | ALGOL |
ovlivnil | Modula-2 , Oberon , Component Pascal , Ada , Object Pascal , Java [2] [3] [4] , Oxygene |
webová stránka | iso.org/standard/18237.h… |
Mediální soubory na Wikimedia Commons |
Pascal jejeden z nejznámějších programovacích jazyků [ 5 ] , používaný pro výuku programování na střední škole a v prvních ročnících vysokých škol, je základem pro řadu dalších jazyků.
Programovací jazyk Pascal byl vytvořen v roce 1970 na základě jazyka Algol-60 [6] .
Pascal vytvořil Niklaus Wirth v letech 1968-1969 po jeho účasti na práci výboru pro vývoj jazykových standardů Algol-68 . Jazyk je pojmenován po francouzském matematikovi, fyzikovi, spisovateli a filozofovi Blaise Pascalovi , který vytvořil jeden z prvních mechanických strojů na světě pro sečtení dvou čísel . Wirthova první publikace o jazyce pochází z roku 1970; při prezentaci jazyka autor označil za cíl jeho vytvoření konstrukci malého a efektivního jazyka, který podporuje dobrý styl programování pomocí strukturovaného programování a strukturovaných dat.
Wirthovou následnou prací bylo vytvořit systémový programovací jazyk založený na Pascalu a zároveň si na jeho základě zachovat schopnost vést systematický, holistický kurz profesionálního programování: „ Vůdčí myšlenkou bylo zkonstruovat skutečného nástupce Pascalu splňujícího požadavky systémového inženýrství. , ale také uspokojit nutkání mého učitele prezentovat systematický, konzistentní, přitažlivý a naučitelný rámec pro profesionální programování. ". Výsledkem této práce byl jazyk Modula-2 , po kterém Wirth začal vyvíjet objektově orientovaný programovací jazyk Oberon na základě veškerého předchozího vývoje [6] .
Niklaus Wirth považoval za jeden z cílů vytvoření jazyka Pascal učit studenty strukturálnímu programování. Až dosud je Pascal právem považován za jeden z nejlepších jazyků pro počáteční výuku programování. Jeho moderní modifikace, jako je Object Pascal, jsou široce používány v průmyslovém programování (prostředí Delphi). Na základě syntaxe jazyka Pascal byl také vytvořen programovací jazyk Structured Text (ST) nebo Structured Control Language (SCL) pro programovatelné logické automaty .
V devadesátých letech se Pascal stal jedním z celosvětově nejrozšířenějších algoritmických programovacích jazyků. Přední vývojáři softwaru pravidelně vydávali nové verze svých kompilátorů pro tento jazyk. Populární kompilátory té doby: Turbo Pascal (vyvinutý společností Borland ), Microsoft Pascal Compiler, Quick Pascal, Pascal-2, Professional Pascal, USCD Pascal [7] .
Jazyk Pascal má mnoho implementací [8] .
V roce 1978 byl na University of California v San Diegu vyvinut UCSD p-System , který zahrnoval port kompilátoru Wirth z jazyka Pascal do portable p-code , editor zdrojového kódu, systém souborů atd. [9 ] a také implementoval značné množství jazykových rozšíření Pascal, jako jsou moduly, řetězce znaků s proměnnou délkou, překladové direktivy, zpracování I/O chyb, odkazování na soubory podle názvu a další. Následně byly na tomto dialektu založeny hlavní implementace jazyka Pascal.
V roce 1986 Apple vyvinul objektové rozšíření jazyka Pascal, jehož výsledkem je Object Pascal . Byl vyvinut skupinou Larryho Teslera , který konzultoval s Niklausem Wirthem .
V roce 1983 se objevila první verze integrovaného vývojového prostředí Turbo Pascal společnosti Borland , založené na stejnojmenné implementaci Pascalu.
V roce 1989 bylo do Turbo Pascal verze 5.5 přidáno rozšíření objektového jazyka.
Nejnovější verze (7.0) byla přejmenována na Borland Pascal.
Objektová zařízení byla vypůjčena z Object Pascal společnosti Apple a mezi Object Turbo Pascal 5.5 a Object Pascal je velmi málo jazykových rozdílů.
Téměř ve stejnou dobu jako Borland vydal Microsoft svou verzi objektově orientovaného jazyka Pascal. [10] [11] Tato verze Pascalu nebyla široce používána.
Další vývoj implementace Pascal od Borlandu dal vzniknout Borlandově variantě Object Pascal , později při vývoji programovacího prostředí Delphi , které dostalo stejný název .
Důležitým krokem ve vývoji jazyka je vznik volných implementací jazyka Pascal Free Pascal a GNU Pascal , které nejenže absorbovaly vlastnosti mnoha dalších dialektů tohoto jazyka, ale také zajistily extrémně širokou přenositelnost programů v něm napsaných. (například GNU Pascal podporuje více než 20 různých platforem, pod více než 10 různými operačními systémy, Free Pascal poskytuje speciální režimy kompatibility s různými běžnými dialekty jazyka, jako je Turbo Pascal (plná kompatibilita), Delphi a další).
Od Delphi 2003 byla vytvořena jazyková implementace pro platformu .Net , ačkoli vývojáři nadále používají Delphi z dřívějších verzí.
O komerčním vývoji ve Free Pascalu, GNU Pascalu a TMT Pascalu je v současné době známo jen málo.
Southern Federal University navíc vyvinula PascalABC.NET , programovací jazyk Pascal, který zahrnuje většinu funkcí jazyka Delphi a také řadu vlastních rozšíření. Je založen na platformě Microsoft.NET a obsahuje téměř všechny funkce moderního jazyka: třídy , přetěžování operátorů , rozhraní , zpracování výjimek , generické třídy a podprogramy , garbage collection , lambda výrazy .
Vlastnosti jazyka jsou přísné typování a dostupnost strukturálních (procedurálních) programovacích nástrojů . Pascal byl jedním z prvních takových jazyků. Jazyk by měl podle Wirtha přispívat k disciplinovanému programování, proto jsou spolu se silným psaním v Pascalu minimalizovány případné syntaktické nejednoznačnosti a autor se snažil o intuitivní samotnou syntaxi již při prvním seznámení s jazykem.
Zpočátku však měl jazyk řadu omezení: nemožnost předat funkcím pole proměnné délky, nedostatek normálních prostředků pro práci s dynamickou pamětí , omezená I/O knihovna , nedostatek prostředků pro připojení funkcí napsaných v jiných jazycích. jazyků, nedostatek samostatných kompilačních nástrojů atd. Podrobný rozbor nedostatků tehdejšího jazyka Pascal provedl Brian Kernighan v článku „Proč Pascal není můj oblíbený programovací jazyk“ [12] (tento článek se objevil na počátku 80. let, kdy se Modula-2 , potomek Pascala, zbavil většiny svých neřestí a také rozvinutějších dialektů Pascalu). Některé nedostatky Pascalu byly opraveny v normě ISO z roku 1982, zejména se v jazyce objevila otevřená pole, která umožnila použít stejné postupy pro zpracování jednorozměrných polí různých velikostí.
Mnoho nedostatků jazyka se však při učení programování neprojeví nebo se dokonce stanou výhodami. Pascal navíc ve srovnání s hlavním programovacím jazykem v akademickém prostředí 70. let (kterým byl Fortran , který měl mnohem výraznější nedostatky) představoval výrazný krok vpřed. V osmdesátých letech se Pascal stal základem pro četné vzdělávací programy, v některých případech byly na jeho základě vytvořeny specializované výukové programovací jazyky, například na počátku osmdesátých let v SSSR Andrei Ershov vyvinul jazyk podobný Algol-Pascal naučit školáky základům informatiky a výpočetní techniky. „ učení algoritmického jazyka “.
Nejznámější implementací Pascalu, která zajistila širokou distribuci a rozvoj jazyka, je Turbo Pascal od Borlandu , který se poté rozrostl v objektový Pascal pro DOS (od verze 5.5) a Windows a dále do Delphi, ve kterém je významný jazyk byla zavedena rozšíření.
Poté, co se v roce 1970 začalo používat Pascal a objevily se implementace, které se lišily nejen doplňky, ale i syntaxí, byla nastolena otázka standardizace jazyka. Jazykový standard vyvinul Niklaus Wirth v roce 1974 s Kathleen Jensen. [13] Následně byl přijat mezinárodní standard od ISO a americký standard od ANSI. V tuto chvíli existují tři zásadně odlišné standardy: Unextended Pascal (původní), Extended Pascal (rozšířený), Object-Oriented Extensions to Pascal (objektově orientované rozšíření Pascalu).
název | Volba | Kdo/kde se vyvinul | Rok vytvoření |
---|---|---|---|
Pascal Standard | počáteční | N. Wirth, Kathleen Jensen | 1974 |
Pascal Standard | počáteční | ISO 7185:1983 ANSI/ IEEE 770X3.97:1983 |
1982 |
Neprodloužený Pascal | počáteční | ISO 7185:1990 | 1989 |
Rozšířený Pascal | prodloužený | ANSI/IEEE 770X3.160:1989 | 1989 |
ISO/ IEC 10206 | 1991 | ||
Objektově orientovaná rozšíření pro Pascal [14] |
objektově orientované rozšíření | ANSI/X3-TR-13:1994 | 1993 |
Jednou z hlavních dodatečných vlastností objektově orientovaného rozšíření Extended Pascal byla modularita a zařízení, která usnadňují samostatnou kompilaci.
Standardizace jazyka zaostávala za skutečným výskytem určitých rysů v jazyce. Komerční implementace rozšířily standardní Pascal; toto bylo provedeno v UCSD Pascal, Appleově modifikaci Object Pascal , Borland Turbo Pascal (mírně upravená verze Apple) a jeho odnožích. Žádná z běžných komerčních implementací Pascalu přesně neodpovídá žádnému z oficiálních jazykových standardů.
Pascal je ve své původní podobě čistě procedurální jazyk a zahrnuje mnoho struktur podobných Algolu a vyhrazených slovních konstruktů jako if, then, else, while, foratd repeat. Pascal však také obsahuje velké množství možností pro strukturování informací a abstrakcí, které chybí z původního Algol-60 , jako jsou definice typů , záznamy , ukazatele , výčty a sady . Tyto konstrukce byly částečně zděděny nebo inspirovány Simula -67 , Algol-68 vytvořil Niklaus Wirth AlgolWa navrhl Hoare .
V moderních dialektech (Delphi Pascal, Free Pascal) jsou k dispozici operace jako přetížení operátorů a funkcí.
Programy v Pascalu začínají klíčovým slovem Program , za nímž následuje název programu, za nímž následuje středník (v některých dialektech volitelný), za jménem může v závorkách následovat seznam externích deskriptorů souborů ("prostředí") jako parametrů; za ním následuje tělo programu skládající se z částí popisujících konstanty ( Const), typy ( Type), proměnné ( Var), deklarace procedur ( Procedure) a funkcí ( Function) a za nimi následující blok příkazů , který je vstupním bodem do program. V Pascalu je blok omezen na klíčová slova begina end. Příkazy jsou odděleny středníkem , za tělem je umístěna tečka , která slouží jako znak konce programu.
Na velikosti písmen v Pascalu nezáleží.
Nejjednodušší („prázdný“) program Pascal by tedy vypadal takto:
program p ; začátek konec .Výše uvedený program nedělá nic a obsahuje prázdný blok příkazů.
Příklad programu, který vypíše řetězec " Ahoj, světe!" »:
program ahoj ; začít writeln ( 'Ahoj, světe!' ) ; // výstupní operátor řetězce konec .Ve standardním a rozšířeném Pascalu existují jednoduché typy: s plovoucí desetinnou čárkou ( real), celá čísla ( integer), znak ( char), booleovský ( boolean) a výčty (nový typový konstruktor představený v Pascalu).
Turbo Pascal přidal do jazyka varianty těchto typů: například shortintbude kratší integera bude longint delší.
Moderní dialekty Pascalu, jako je FPC nebo Delphi , se domnívají, že integer - toto je celé číslo nejvhodnější pro daný stroj, používané například pro indexy pole , a shortint, longinta další - celá čísla určité délky; to je užitečné pro programování napříč platformami . Stejně tak u zlomkových čísel.
Typy byly znovu rozšířeny při přechodu na x64 - „jen celé číslo“ ( integer) zůstalo 32bitové, ale byl vyžadován speciální typ, který se rovná longintx86 a int64x64.
Typy celých čísel:
Typ | Rozsah | Formát | Velikost v bajtech | Poznámky |
---|---|---|---|---|
bajtů | 0..255 | nepodepsaný | jeden | |
ShortInt | −128..127 | ikonický | jeden | |
SmallInt | −32768..32767 | ikonický | 2 | Nemusí existovat; místo toho celé číslo se stejným rozsahem |
Slovo | 0..65535 | nepodepsaný | 2 | |
dlouhé slovo | 0..4294967295 | nepodepsaný | čtyři | |
LongInt | −2147483648..2147483647 | ikonický | čtyři | |
int64 | −9223372036854775808..9223372036854775807 | ikonický | osm | |
QWord | 0..18446744073709551615 | nepodepsaný | osm | |
Celé číslo | -32768..32767. | ikonický | 2 nebo 4 | Nejrychlejší celé číslo; SmallInt nebo LongInt |
kardinál | ? | nepodepsaný | ? | Nejrychlejší celé číslo; obvykle LongWord |
NativeInt | ? | ikonický | ? | Odpovídá registru stroje; LongInt nebo Int64 |
NativeUInt | ? | nepodepsaný | ? | Odpovídá registru stroje; LongWord nebo QWord |
Čísla s plovoucí desetinnou čárkou:
Typ | Rozsah | Počet platných číslic | Velikost v bajtech | Podpěra, podpora |
---|---|---|---|---|
Nemovitý | závislé na platformě | ??? | ??? | Všechny kompilátory; na moderních je obvykle ekvivalentní Double |
Skutečné 48 | 2.9E−39..1.7E38 | 11-12 | 6 | Borland; v Turbo Pascalu se to jmenovalo Real; nepoužívá koprocesor a proto se výsledek opakuje do bitu |
Singl | 1.5E−45..3.4E38 | 7-8 | čtyři | Většina možností pod stroji vyhovujícími IEEE 754 |
Dvojnásobek | 5.0E-324..1.7E308 | 15–16 | osm | Většina možností pod stroji vyhovujícími IEEE 754 |
Rozšířené | 3.4E-4951..1.1E4932 | 19–20 | deset | Většina možností pro x86 |
Comp | −9223372036854775808..9223372036854775807 | osm | Borland; 8bajtové celé číslo vypočítané na koprocesoru; relevantní pro 16bitové x86 | |
Měna | −922337203685477.5808..922337203685477.5807 | osm | Borland a další kompilátory pro Windows; spojené s OLE ; pevný bod s jednotkou rovnou 10000 |
V Pascalu jsou bitové operace povoleny na celočíselných typech (byte, shortint, word, integer, longint a jejich rozsahy). Logické operace s bity:
Na bitech dvou celočíselných operandů můžete provádět dříve uvažované logické operace: not a, nebo, xor. Rozdíl mezi bitovými a logickými operacemi je v tom, že bitové (bitové) operace se provádějí s jednotlivými bity operandů, nikoli s jejich hodnotou v desítkové (obvykle) reprezentaci.
Rozlišuje se koncept ordinálních datových typů (ordinální), zahrnují celočíselné typy (se znaménkem a bez znaménka), logické ( boolean), znakové ( char), výčtové typy a typy rozsahů.
Ordinální typy jsou určeny celým číslem (kódem), který lze získat pomocí funkce ord. Všechny operace prováděné na ordinálních typech se provádějí na jejich kódech.
Rozsahy obsahují podmnožinu hodnot jiných ordinálních typů:
var x : 1 .. 10 ; y : 'a' .. 'z' ; z : hruška..oranžová ; _ _Pro ordinální typy jsou definovány operace inc, dec, succ, pred, ord, porovnávací operace ( = > < => <= <>), lze je použít v operátorech case, for(jako čítač smyček), jako hranice pole, pro specifikaci prvků množin a typů rozsahů.
V Pascalu, na rozdíl od jazyků podobných C, nejsou celočíselné aritmetické operace definovány pomocí booleantypů char.
SadyNa rozdíl od mnoha běžných jazyků Pascal podporuje speciální datový typ sady :
var set1 : sada 1 .. 10 ; _ sada2 : sada 'a' .. ' z ' ; sada 3 : sada hrušek ..oranžová ; _Množina je základní pojem v moderní matematice, který lze použít v mnoha algoritmech.
V Pascalu může typ sady obsahovat pouze prvky stejného typu ordinálního typu. Tato funkce je široce používaná a je obvykle rychlejší než ekvivalentní konstrukce v jazyce, který nepodporuje sady. Například pro většinu kompilátorů Pascal:
if i v [ 5 .. 10 ] then { kontrola , zda prvek patří do množiny } ...zpracováno rychleji než
if ( i >= 5 ) and ( i <= 10 ) then { boolean test } ...K nastavení hodnoty množiny se používá seznam prvků množiny, oddělených čárkami a uzavřených v hranatých závorkách (jak již bylo uvedeno výše):
var { sekce deklarace proměnné } d : sada znaků ; begin { začátek bloku } d := [ 'a' , 'b' ] ; ...V Jensenově a Wirthově Pascalu byly řetězce reprezentovány jako sbalená pole znaků; proto měly pevnou délku a byly obvykle na tuto délku vycpané mezerami.
Kompozitní typyNové typy lze definovat ze stávajících:
type { sekce deklarace typu } x = Integer ; y = x ; ...Kromě toho lze kompozitní typy konstruovat z primitivních typů:
type { sekce deklarace typu } a = Array [ 1 .. 10 ] of Integer ; { definice pole } b = záznam { definice záznamu } x : Integer ; y : Char ; konec ; c = Soubor a ; _ { definice souboru }Typy souborů v Pascalu se dělí na typizované, textové a soubory bez typů.
Jak je ukázáno v příkladu výše, zadané soubory v Pascalu jsou sekvence prvků stejného typu. Pro každý soubor existuje proměnná ukazatele vyrovnávací paměti, označená f^. Procedury get(pro čtení) a put(pro zápis) přesunou ukazatel na další prvek. Čtení je realizováno tak, read(f, x)že je stejné jako get(f); x:=f^. Proto je záznam implementován takovým způsobem, write(f, x)že je stejný jako f^ := x; put(f). Textové soubory jsou textdefinovány jako přípona typu file of chara kromě standardních operací s typizovanými soubory (čtení, zápis znaku) umožňují znakový vstup / výstup do souboru všech typů dat, podobně jako vstup / výstup konzole.
Soubory bez typů jsou deklarovány jako proměnné typu file. S nimi můžete provádět bajt po byte netypové I/O operace pro několik bloků bajtů zadané délky prostřednictvím vyrovnávací paměti, k čemuž se používají speciální procedury blockreada blockwrite(rozšíření UCSD).
ŘetězceModerní Pascal [15] používá pro práci s řetězci vestavěný typ string, který podporuje zřetězení ( +) a porovnání ( > < = <> >= <=). Řetězce jsou porovnávány v lexikografickém pořadí . Například řetězce jsou považovány za rovnocenné, pokud mají stejnou délku a kódy všech znaků se stejným indexem se shodují.
Typ string [n]nebo jednoduše stringv dialektech jazyka 70. a 90. let byl definován jako pole znaků array [0..n] of char(n ve výchozím nastavení mělo hodnotu 80 v UCSD Pascal a 255 v Turbo / Borland Pascal), nulový prvek pole v tomto reprezentace slouží k nastavení délky řetězce, resp. řetězec může mít maximální velikost 255 znaků. Ve výchozím nastavení se v Delphi a FreePascal používá typ AnsiString jako String, jehož paměť je dynamicky alokována a uvolňována kompilátorem a maximální velikost řetězce v aktuálních implementacích je 2 gigabajty. Navíc v Delphi a Free Pascal lze jako typ použít typ UnicodeString, kde se používá 16bitová reprezentace znaků v stringkódování UCS-2 , přičemž neexistují žádné prostředky pro převod z jednobajtových řetězců na vícebajtové řetězce. a zpět ve standardní knihovně FPC, ale jsou k dispozici v Delphi.
Delphi 2009 a vyšší má konstrukci pro deklarování AnsiString se specifickou kódovou stránkou:
zadejte CyrillicString = AnsiString ( 1251 ) ; CP866String = AnsiString ( 20866 ) ; UkazatelePascal podporuje použití ukazatelů (zadaných ^типa nezadaných pointer):
typ a = ^ b ; b = záznam x : Integer ; y : Char ; z : a ; konec ; var pointer_to_b : a ;Zde je proměnná pointer_to_b ukazatel na datový typ b, což je záznam. Typovaný ukazatel může být definován ( dopředu ) před deklarací typu, na který odkazuje. Toto je jedna z výjimek z pravidla , které říká, že jakýkoli prvek (konstanta, typ, proměnná, procedura, funkce) musí být před použitím deklarován . Zavedení této výjimky umožňuje organizovat opakující se definice datových struktur, včetně lineárních seznamů , zásobníků , front , stromů, včetně ukazatele na položku v popisu této položky (viz také: nulový ukazatel - nil).
Pro typovaný ukazatel je definována operace dereference (její syntaxe je: указатель^).
Chcete-li vytvořit nový záznam a přiřadit hodnotu 10a symbol k Apolím xa yv něm, jsou vyžadovány následující příkazy:
new ( ukazatel_na_b ) ; { přidělení paměti ukazateli } pointer_to_b ^. x := 10 ; { dereferencování ukazatele a přístup k poli záznamu } pointer_to_b ^. y := 'A' ; pointer_to_b ^. z : = nula ... zlikvidovat ( ukazatel_na_b ) ; { uvolnění paměti pod ukazatelem }Operátor můžete také použít k odkazování na pole v záznamech a objektech with, jak ukazuje příklad:
new ( ukazatel_na_b ) ; s pointer_to_b ^ do begin x := 10 ; y := 'A' ; z := nil end ; ... zlikvidovat ( ukazatel_na_b ) ; Procedurální typV původním jazyce Pascala Jensena a Wirtha byl procedurální typ použit pouze při popisu formálního parametru. V TP již existoval úplný procesní typ . Deklarace typu obsahuje hlavičku procedury nebo funkce (bez názvu), která obecně popisuje rozhraní podprogramu. Hodnota tohoto typu obsahuje ukazatel na podprogram s názvem odpovídajícím tomu, který je deklarován v deklaraci typu. K volání odpovídající procedury nebo funkce lze použít identifikátor proměnné.
Příklad podprogramu pro Pascal typ myfunc = funkce : řetězec ; func1 : řetězec ; _ begin func1 := 'func #1' end ; func2 : řetězec _ _ begin func2 := 'func #2' end ; var fun : my func ; začít se bavit :=@ func1 ; writeln ( zábava ) {funkce func1 se nazývá} end .Pascal je strukturovaný programovací jazyk , což znamená, že program se skládá ze samostatných standardních příkazů, které se provádějí postupně, ideálně bez použití příkazu GOTO.
Příklad pro Pascal while a <> b do { smyčka s předpokladem } writeln ( 'Čekání' ) ; if a > b then { podmíněný příkaz } writeln ( 'Podmínka splněna' ) else { else-section - může být vynechána} writeln ( 'Podmínka selhala' ) ; for i := 1 až 10 do { iterační smyčka } writeln ( 'Iterace #' , i : 1 ) ; for i in [ 1 .. 10 ] do { iterate through the set } writeln ( 'Iteration #' , i : 1 ) ; { objevilo se ve verzi 2.4.0 } with a do {Operátor With - metoda pro urychlení přístupu k polím záznamu} begin l := 1 ; k := 2 ; p :=- 3 ; konec ; opakuj { smyčka po podmínce } a := a + 1 dokud a = 10 ; case i { podmíněný operátor s více volbami } 0 : zápis ( 'nula' ) ; 1 : napsat ( 'jeden' ) ; 2 : napište ( 'dva' ) else napište ( 'neznámé číslo' ) { else-section - může být vynechána} end ;V příkazech while, for, if, lze blokcase použít jako spustitelný příkaz . Taková konstrukce, která je obyčejným příkazem nebo blokem, se nazývá komplexní příkaz .
V Turbo Pascalu jsou pro řízení procesu kompilace k dispozici direktivy, které jsou umístěny v komentářích a umožňují přepínat provozní režimy kompilátoru - například povolit a zakázat kontroly I/O operací, přetečení:
Příklad pro Pascal přiřadit ( inp , 'text.txt' ) ; {$I-} { zakázat režim kontroly IO - generování ukončovacího kódu programu v případě chyby I/O } { (pro případ, že soubor není nalezen)} reset ( inp ) ; {$I+} { povolit režim kontroly IO } if IOresult = 0 then begin { zkontrolujte hodnotu proměnné ioresult(<>0 v případě chyby I/O) } ... close ( inp ) ; end else writeln ( 'soubor nenalezen' )Existují direktivy podobné direktivám preprocesoru C/C++ ( $ifdef, $define, $include), zpracovává je kompilátor při kompilaci.
V Pascalu jsou podprogramy rozděleny na procedury a funkce. Funkce přitom explicitně vracejí hodnotu (výsledek) určitého typu a procedury výslovně nic nevracejí.
Syntakticky se popis procedury nebo funkce skládá z hlavičky obsahující klíčové slovo procedurenebo function, jméno, po kterém může následovat popis předávaných (formálních) parametrů v závorkách. :U funkce je typ návratové hodnoty označen symbolem dvojtečky . Název končí středníkem ;. Za záhlavím následuje tělo , které (případně) obsahuje části popisu lokálních konstant, typů, proměnných, procedur, funkcí a (povinné) obsahující blok příkazů, za nímž následuje středník ;.
Příklad programu pro Pascal programový ( výstup ) ; _ var i : celé číslo ; tisk procedury ( var j : integer ) ; funkce next ( k : integer ) : integer ; začít další := k + 1 konec ; begin writeln ( 'Celkem: ' , j ) ; j := další ( j ) konec ; začít i := 1 ; zatímco i <= 10 do print ( i ) end .Tělo procedury, stejně jako program, může zase obsahovat popisy procedur a funkcí. Procedury a funkce tak mohou být do sebe vnořeny tak hluboko, jak je potřeba, přičemž tělo programu je v řetězci nejvýše položené.
Navíc je v něm k dispozici obsah sekcí popisu proměnných, typů, konstant, externího těla (procedur, funkcí, programů) umístěných před popisem procedury/funkce. Ve většině dialektů také můžete přistupovat k parametrům externí procedury z procedury.
Za hlavičkou procedur/funkcí lze místo těla umístit klíčové slovo forward, to se provádí, pokud se popis procedury/funkce nachází v programu po jeho volání a je spojen s možností kompilace programu v jeden průchod podporovaný v Pascalu.
Pascalovy standardní matematické funkce a procedury Matematické funkceNázev funkce | Typ argumentu | Typ hodnoty | Výsledek výpočtu |
Abs(x) | celý skutečný | celý skutečný | absolutní hodnota "x" |
hřích(x) | nemovitý | nemovitý | sinus "x" rad. |
cos(x) | nemovitý | nemovitý | kosinus "x" rad. |
arktan(x) | nemovitý | nemovitý | arkus tangens "x" ( -Pi/2 <y< Pi/2 ) |
Sqrt(x) | nemovitý | nemovitý | druhá odmocnina z "x" |
Sqr(x) | celý skutečný | celý skutečný | hodnota "x" na druhou ( x 2 ) |
moc (a,x) | nemovitý | nemovitý | hodnota "a" na mocninu "x" ( a x ) |
exp(x) | nemovitý | nemovitý | hodnota "e" na mocninu "x" ( e x , kde e= 2,718282... ) |
Ln(x) | nemovitý | nemovitý | přirozený logaritmus "x" ( x > 0 ) |
frac(x) | nemovitý | nemovitý | zlomková část "x" |
Int(x) | nemovitý | nemovitý | celá část "x" |
Náhodný | - | nemovitý | náhodné číslo ( 0 <=y< 1 ) |
Náhodné (x) | Slovo | Slovo | náhodné číslo ( 0 <=y< x ) |
Succ(c) | řadové | řadové | znak následující po "s" |
před(c) | řadové | řadové | předcházející znak "s". |
Název funkce | Typ argumentu | Typ hodnoty | Výsledek výpočtu |
Inc(x) | Celý | Celý | Zvětší "x" o 1 ( x:=x+1; ) |
prosince(x) | Celý | Celý | Sníží "x" o 1 ( x:=x-1; ) |
Inc(x, n) | Celý | Celý | "x" krát n ( x:=x+n; ) |
prosinec(x, n) | Celý | Celý | "x" krát n ( x:=xn; ) |
Název funkce | Typ argumentu | Typ hodnoty | Výsledek výpočtu |
Str(x, s) | x-integer nebo real | s-řetězec | Posloupnost znaků "s" z číslic čísla "x" |
Val(s, v, cod) | s-řetězec | v-integer nebo real cod-integer | Binární forma pořadového čísla "s" cod=0 (kód chyby) |
Název funkce | Typ argumentu | Typ hodnoty | Výsledek výpočtu |
Trunc(x) | nemovitý | LongInt | celá část "x" |
kolo(x) | nemovitý | LongInt | zaokrouhlení "x" na celé číslo |
Lichý (x) | Celý | logický | vrátí True, pokud je "x" liché číslo |
Chr(x) | bajtů | Char | znak ASCII kódu "x" |
Ord(x) | Char | bajtů | ASCII kód znaku "x" |
Před příchodem připojených modulů v jejich moderní podobě podporovaly některé implementace Pascalu modularitu díky mechanismu pro vkládání hlavičkových souborů, podobně jako mechanismus #includev jazyce C: pomocí speciální direktivy formátované jako pseudokoment, například {$INCLUDE "файл"}, obsah zadaného souboru byl přímo zahrnut do zdrojového kódu programu. , v textové podobě. Bylo tedy možné rozdělit programový kód na mnoho fragmentů, pro snadnou editaci, ale před kompilací byly automaticky spojeny do jednoho programového souboru, který byl nakonec zpracován kompilátorem. Tato implementace modularity je primitivní a má mnoho zjevných nedostatků, takže byla rychle nahrazena.
Moderní implementace Pascalu (počínaje UCSD Pascalem) podporují moduly. Programové moduly mohou být dvojího typu: hlavní programový modul, který jako obvykle začíná klíčovým slovem program a jehož tělo obsahuje kód, který se spustí po načtení programu do paměti, a pomocné moduly obsahující typy, konstanty, proměnné, procedury. a funkce určené pro použití v jiných modulech, včetně hlavního modulu.
StrukturaObecná struktura zásuvného modulu v Pascalu je následující:
jednotka NázevJednotky1 ; rozhraní ... implementace ... begin {může být vynecháno - používá se, pokud je třeba umístit inicializační příkazy} ... end .Je možná i jiná možnost:
jednotka NázevJednotky2 ; rozhraní ... implementace ... inicializace ... finalizace .... konec .Na rozdíl od hlavního programu začíná soubor modulu klíčovým slovem UNITnásledovaným názvem modulu a středníkem. Moderní implementace obvykle vyžadují, aby byl název modulu stejný jako název souboru zdrojového kódu, který modul obsahuje. Modul obsahuje tři části: část rozhraní, část implementace a tělo modulu.
Sekce rozhraní je na prvním místě, začíná klíčovým slovem INTERFACEa končí v bodě modulu, kde začíná implementační sekce nebo tělo. Sekce rozhraní deklaruje ty objekty (typy, konstanty, proměnné, procedury a funkce – pro ně jsou umístěny hlavičky), které musí být dostupné mimo modul. V tomto případě je povolena částečná deklarace typů: mohou být deklarovány bez určení struktury, pouze s jedním jménem. Při použití tohoto typu v externím programu je povoleno deklarovat proměnné a parametry tohoto typu, přiřazovat hodnoty, ale nelze se dostat k detailům jeho implementace. Procedury a funkce v sekci rozhraní jsou deklarovány jako forwardy - hlavičky s parametry, ale bez těla. Složení sekce rozhraní modulu je takové, že stačí vygenerovat kód, který tento modul používá. Proměnné deklarované v sekci rozhraní jsou globální, to znamená, že existují v jediné instanci a jsou dostupné ve všech částech programu, které používají tento modul.
Sekce implementace následuje po sekci rozhraní a začíná klíčovým slovem IMPLEMENTATION. Obsahuje popisy procedur a funkcí deklarovaných v sekci rozhraní a také popisy typů, konstant, proměnných, procedur a funkcí, které jsou nezbytné k implementaci procedur a funkcí rozhraní. Popis procedury nebo funkce deklarované v sekci rozhraní musí mít přesně stejný nadpis jako v deklaraci. Tělo může využívat další postupy a funkce tohoto modulu, deklarované jak v části rozhraní, tak v části implementace. Proměnné deklarované v implementační části jsou ve skutečnosti globální (to znamená, že v celém programu existuje pouze jedna instance každé takové proměnné), ale jsou přístupné pouze z procedur a funkcí popsaných v implementační části tohoto modulu, i z jeho těla. Pokud jsou v sekci rozhraní zkrácené deklarace typů, pak musí být tyto typy plně deklarovány v sekci implementace.
Tělo modulu začíná klíčovým slovem na nejvyšší úrovni vnoření BEGIN. Tělo obsahuje programový kód, který se provede jednou při načtení modulu. Tělo lze použít pro inicializaci, přiřazování počátečních hodnot proměnným modulu, přidělování zdrojů pro jeho provoz a tak dále. Tělo modulu může chybět. V řadě implementací Pascalu, například v Delphi, lze místo těla modulu použít dvě sekce (také volitelné) - INITIALIZATIONa FINALIZATION. Jsou umístěny na konci modulu za odpovídajícím klíčovým slovem. První, inicializační část, obsahuje kód, který se musí provést při načtení modulu, druhá, finalizační část, obsahuje kód, který bude proveden při vyjmutí modulu. Sekce finalizace může provádět akce, zpětné inicializace – odebírat objekty z paměti, zavírat soubory, uvolňovat přidělené zdroje.
Modul končí klíčovým slovem ENDtečka .
PoužitíPro použití modulu musí hlavní program nebo jiný modul modul importovat, to znamená obsahovat prohlášení o jeho použití. Tato deklarace se provádí pomocí příkazu include modulu, což je klíčové slovo USESnásledované čárkami odděleným názvem modulů, které mají být zahrnuty. Instrukce pro připojení musí bezprostředně následovat za hlavičkou programu nebo za klíčovým slovem INTERFACE, pokud je připojení vytvořeno v modulu.
Moduly zapojené v sekci rozhraní lze použít v celém modulu - jak v implementační sekci, tak v těle. Implementační sekce však může mít vlastní instrukci include (následuje za klíčovým slovem IMPLEMENTATION) obsahující názvy zásuvných modulů, které nejsou v sekci rozhraní, ale jsou potřebné v implementační sekci. Jedním z důvodů pro použití samostatného seznamu připojení pro implementační sekci je situace, kdy se dva nebo více modulů navzájem používají. Aby se předešlo cyklickým odkazům v prohlášeních o použití takových modulů, musí alespoň jeden z nich zahrnovat druhý v sekci implementace.
Jakékoli objekty deklarované v sekcích rozhraní modulů lze použít v programu, kde jsou tyto moduly připojeny. Názvy objektů importovaných ze zásuvných modulů zůstávají stejné a lze je přímo použít. Pokud dva nebo více připojených modulů má objekty se stejným názvem a kompilátor je nedokáže rozlišit, pak při pokusu o použití takového objektu dojde k chybě kompilace - nejednoznačná specifikace názvu. V tomto případě musí programátor použít kvalifikaci jména - zadejte jméno ve formátu "<jméno_modulu>.<jméno_objektu>".
Problémy mohou nastat, pokud je potřeba v programu použít dva různé moduly stejného jména. Pokud jsou moduly dostupné pouze v kompilované podobě (tj. nelze změnit jejich názvy), není možné je současně importovat. Pro takovou kolizi na jazykové úrovni neexistuje standardní řešení, konkrétní kompilátory však mohou nabídnout ten či onen způsob, jak ji obejít, zejména způsob přidělování aliasů importovaným modulům a přímou specifikaci, který modul má z kterého souboru převzít.
Kompilace a propojeníModuly jsou navrženy tak, aby byly samostatně zkompilované - kompilátor nemusí kompilovat importované moduly, aby mohl zkompilovat modul, který je používá. Pro správnou kompilaci modulu však kompilátor musí mít přístup k části rozhraní všech modulů, které používá. Existují dva různé, někdy kombinované přístupy k organizaci takového přístupu.
Pro normální provoz modulu může být nutné provést některé akce před jeho použitím: inicializovat proměnné, otevřít potřebné soubory, alokovat paměť nebo jiné zdroje. To vše lze provést v těle modulu, případně v sekci inicializace. Opačná inicializace se provádí v sekci finalizace.
Pořadí inicializace a finalizace modulů je nepřímo určeno pořadím deklarace v sekci použití, ale u staticky zkompilovaných programů (kde je modul buď zkompilován do jednoho spustitelného souboru s hlavním programem, nebo umístěn v samostatné dynamické knihovně), ale načten ve fázi počátečního načtení), kompilátor vždy zaručuje, že inicializace bude provedena před prvním použitím modulu. Finalizace se provádí při ukončení programu, po ukončení hlavního modulu, takže používané moduly jsou dokončeny později než ty, které je používají.
V případě dynamického načítání modulů řízených samotným programátorem se inicializátory provádějí při načítání, tedy v okamžiku, kdy příkaz k načítání modulu vrátil řízení, jeho inicializátor již byl proveden. Finalizátor se spustí po vyložení, obvykle při provedení příkazu vyložení modulu. Pokud tento příkaz není zavolán, dynamicky načítané moduly jsou finalizovány stejným způsobem jako všechny ostatní moduly - po ukončení programu.
Object Pascal má schopnost vyvíjet programy pomocí objektově orientovaného programovacího paradigmatu . Třídy jsou definovány pomocí objectpodobného typu record, který kromě datových polí může obsahovat záhlaví procedur a metod . Názvy popsaných metod následují za názvem třídy odděleným tečkou.
Konstruktor a destruktor jsou specifikovány jako běžné procedury, ale místo identifikátoruspecifikovánaprocedureklíčová slova. V souladu s tím, na rozdíl od jazyků podobných C++ , mají název odlišný od názvu třídy, může existovat několik destruktorů a mohou mít parametry (v praxi se tato funkce používá zřídka, obvykle má třída jeden destruktor, který přepíše virtuální destruktor nadřazené třídy). constructordestructorDestroy
Je podporována jednoduchá dědičnost, polymorfismus tříd , mechanismus virtuálních metod (slovo virtualpo záhlaví metody třídy). Existují také dynamické metody (v TP jsou popsány přidáním celého čísla za slovo virtuala používají se hlavně pro zpracování zpráv; v Delphi a FreePascal se pro tyto účely messagepoužívá slovo a slovo se používá k vytvoření běžných dynamických metod dynamic) , které se vyznačují menším využitím paměti a nižší rychlostí volání kvůli nedostatku duplikace dynamických metod předků ve VMT dítěte (FreePascal však nerozlišuje mezi virtuálními a dynamickými metodami).
V Delphi FPC implementovalo přetížení operátorů , abstraktní metody, direktivy private, protected, public, published(standardně jsou členy třídy public):
Příklad programu pro Pascal typ TbasicO = objektová procedura writeByte ( b : byte ) ; virtuální ; abstraktní ; konec ; TtextO = object ( TbasicO ) { zdědí TbasicO, implementuje další výstupní operace založené na writeByte } procedura writeS ( s : string ) ; {..} konec ; TfileO = objekt ( TbasicO ) {třída výstupu souboru - implementuje výstupní operaci jako výstup bajtu do souboru} konstruktor init ( n : řetězec ) ; procedura writeByte ( b : byte ) ; virtuální ; destruktor closefile ; private f : soubor bajtů ; _ konec ; basicO = ^ TbasicO ; textO = ^ TtextO ; souborO = ^ TsouborO ; konstruktor TfileO . init ( n : řetězec ) ; begin assign ( f , n ) ; přepsat ( f ) konec ; destruktor TfileO . closefile ; begin close ( f ) end ; postup TfileO . writeByte ( b : byte ) ; začít psát ( f , b ) konec ; postup TtextO . writeS ( s : string ) ; var i : celé číslo ; begin for i := 1 to length ( s ) do writeByte ( ord ( s [ i ])) end ; {..} var f : souborO ; begin new ( f , init ( 'tstobj.txt' )) ; {přidělí paměť pro objekt a zavolá konstruktor} textO ( f ) ^. writeS ( 'textový řetězec' ) ; disponovat ( f , closefile ) {zavolá destruktor a uvolní paměť objektu} end .V delfském dialektu lze třídy konstruovat i pomocí slova class(navíc objectnení povoleno vzájemné dědění s -classes) a jsou zavedena rozhraní ( interface) - všechny metody jsou abstraktní a nemohou obsahovat datová pole.
Všechny třídy (vytvořené pomocí class) dědí TObjectz , všechna rozhraní jsou odvozena z IUnknown. Třídy vytvořené pomocí classmohou implementovat více rozhraní.
Rozhraní byla představena v Delphi na podporu technologie COM společnosti Microsoft .
Třídy ( Class) na rozdíl od běžných tříd ( Object) nepotřebují explicitní alokaci/dealokaci paměti, paměť pro ně dynamicky přiděluje konstruktor s názvem Create, volá se s názvem třídy a uvolňuje se, když je zavolán destruktor s názvem Destroy( může mít jiná jména). Proměnná takové třídy, na rozdíl od třídy, objectukládá adresu instance třídy do paměti, hodnota nilse používá k označení prázdného odkazu, proto je pro uvolnění objektu definována TObjectspeciální metoda free, která kontroluje odkaz na nila volá virtuální destruktor Destroy. Kód používající takové třídy by vypadal takto:
Příklad pro Pascal q1 := t1 . vytvořit ( 9 ) ; { construct object(t1 - název třídy) } writeln ( q1 . InstanceSize ) ; { zobrazení velikosti instance třídy } q1 . zdarma ; { zničení objektu } q1 := nula ; { aby se destruktor nevolal znovu, když je voláno free }V modifikaci ObjectPascal/Delphi/FreePascal se v popisu tříd objevují vlastnosti (property), které kombinují pohodlí práce s proměnnými (jejichž roli v OOP hrají pole) a volání metod, které objekt vždy upozorní na tzv. změna jeho stavu:
Příklad programu pro Pascal typ TMyObj = class ( TObject ) FProp : integer ; procedure SetProp ( AValue : integer ) ; vlastnost MyProp : celé číslo čtení FProp zápis SetProp ; konec ; postup TMyObj . SetProp ( AValue : integer ) ; begin FProp := AValue ; Writeln ( 'Někdo změnil MyProp!' ) ; konec ; var MyObj : TMyObj ; begin MyObj := TMyObj . vytvořit ; MůjObj . FProp := 5 ; MůjObj . MyProp := MyObj . MyProp + 6 ; konec .V prvním případě (pomocí MyObj.FProp) bylo pole objektu změněno přímo, v důsledku toho metody objektu nebudou mít podezření, že toto pole bylo dříve změněno; ve složitějším případě se mohou spolehnout na to, že pole bude nezměněno, nebo může být poli přiřazena hodnota, která je pro daný objekt neplatná. Ve druhém případě je hodnota přiřazena přímo vlastnosti objektu, která odkazuje na volání metody, která správně zpracovává změnu daného pole.
Tento přístup je vhodný, pokud je objekt spojen s vizuálním prvkem: přímá změna pole odpovědného například za šířku prvku neovlivní samotný vizuální prvek a objekt bude „dezinformován“ o skutečné velikosti. prvku. Správný přístup bez použití vlastností je vyvinout metody pro získání a nastavení libovolné hodnoty pole, ale práce s takovými metodami bude méně pohodlná, například místo posledního řádku by bylo nutné napsat
MůjObj . SetProp ( MyObj . GetProp + 6 ) ;navíc pro sjednocení přístupu měla být napsána metoda MyObj.GetProp.
Velmi zajímavé jsou vlastnosti indexu, které se chovají v podstatě stejně jako pole a nahrazují přístup k prvku pole voláním odpovídající metody.
Vlastnosti však nejsou „všelékem“: při kompilaci jsou volání vlastností přímo převedena na volání metod nebo přímou práci s poli, takže vlastnosti nejsou skutečné proměnné, zejména je nelze předávat jako parametry var.
Slovníky a encyklopedie | |
---|---|
V bibliografických katalozích |
|
Pascal | |||||||
---|---|---|---|---|---|---|---|
Dialekty |
| ||||||
Kompilátory |
| ||||||
IDE | |||||||
Osoby |
Programovací jazyky | |
---|---|
|
ISO | normy|
---|---|
| |
1 až 9999 |
|
10 000 až 19999 |
|
20 000+ | |
Viz také: Seznam článků, jejichž názvy začínají na „ISO“ |