Documente Academic
Documente Profesional
Documente Cultură
Tipurile structurate: o tipul tablou: array folosit pentru a memora un sir de valori o tipul sir de caractere: string este o secventa dinamica (ca lungime) de caractere. poate lua ca valori un sir de caractere din ASCII (maxim 255 de caractere) stocat intern pe: maxim 256 de bytes (primul e pentru a stoca lungimea sirului (spre deosebire de C / C++, unde sirul se termina cu caracterul #0 - null terminated strings) o tipul inregistrare: record folosit pentru a memora valori de mai multe tipuri in acelasi loc o tipul obiect: object folosit in programarea pe obiecte (OOP) o tipul multime: set folosit pentru a desemna o multime (ca in matematica) de elemente de acelasi tip o tipul fisier: text, file folosit la prelucrarea fisierelor o tipul referinta: pointer folosit la prelucrarea dinamica a memoriei o tipurile procedurale: function, procedure extensie a Pascalului standard, folosite pentru a putea folosi subprogramele ca variabile
Tipuri ordinale
Cum am aratat mai sus, sunt shortint, byte, integer, word , longint. tipurile ordinale de date
In operatii, toate tipurile intregi de date sunt compatibile intre ele. Operatorii aritmetici care se pot folosi sunt: o + (semnul plus) pentru adunare o - (semnul minus) pentru scadere o * (semnul asterisc) pentru inmultire o DIV impartire intreaga - se obtine catul o MOD impartire intreaga - se obtine restul o / (semnul slash) impartire reala - se poate aplica asupra operanzilor intregi, dar rezultatul este real. Tipul Boolean Tipul boolean este ordinal, enumerativ: (FALSE, TRUE). Operatorii logici care i se pot aplica sunt: o NOT operatia logica "nu" o AND operatia logica "si"
o o
OR operatia logica "sau" XOR operatia logica "sau exclusiv" - este adevarat daca un operand este adevarat, dar nu amandoi. A XOR B inseamna "A sau B, dar nu amandoua". Char variabile de sau acest 'a' tip se va (sunt scrie ordinal. intre ghilimele. distincte !)
Operatorii si functiile care se pot aplica asupra acestui tip de data sunt: + concateneaza 2 sau mai multe caractere, dar rezultatul este de tip string o CHR este o functie care se aplica datelor de tip intreg, dar rezultatul este de tip Char. Returneaza caracterul cu codul respectiv din codul ASCII. Alternativ, se poate folosi #. Ex. Chr(65) este egal cu #65, ambele avand valoarea A (caracter)
o
Tipuri reale
Tipurile Datele reale sunt de date memorate sunt single, real, double, extended si comp. intern in virgula mobila.
Tipul comp desemneaza o data reala particulara, avand numai valori intregi. In operatii intra ca o data reala, avand partea zecimala egala cu zero. Operatorii aritmetici (si functii) care se pot aplica tipurilor reale sunt: o + pentru adunare o pentru scadere o * pentru inmultire o / impartire reala (cu virgula) o Trunc functie care returneaza partea intreaga a numarului o Round functie care rotunjeste un numar. Daca partea zecimala este de 0.5 atunci numarul este rotunjit in sus Tipurile structurate vor fi explicate intr-un alt tutorial, necesitand mai multe informatii.
Pentru tipurile ordinale de date, unde exista un predecesor si un succesor distinct pentru fiecare valoare, Pascal ofera functiile prezentate in tabelul de mai jos.
Functii pentru tipuri ordinale Descriere Tip argument caracterul specificat din ASCII intreg valoare ordinala intreg sau caracter predecesor intreg sau caracter succesor intreg sau caracter
Pascal ofera o multitudine de functii matematice, din care voi prezenta cateva mai jos.
Functie abs arctan cos exp ln round sin sqr sqrt trunc
Atentie:
Functii matematice Descriere Tip argument valoare absoluta real sau intreg arctangenta in radiani real sau intreg cosinus de X radiani real sau intreg e la putere real sau intreg logaritm natural real sau intreg rotunjire real sinus de X radiani real sau intreg ridicare la patrat real sau intreg radical real sau intreg rotunjire in jos real sau intreg
Toate functiile trigonometrice din Pascal
Tip rezultat la fel ca argumentul real real real real integer real la fel ca argumentul real integer
lucreaza cu radiani.
Toate functiile expuse aici sunt folosite scriind numele functiei, urmat de argumentul (parametrul) functiei, pus intre paranteze rotunde ( si ). Bineinteles, aceasta lista de functii nu este lista completa de functii si proceduri ale compilatorului Pascal. Compilatoarele moderne de Pascal includ mii de functii pentru toate necesitatile. Sistemul de ajutor (Help) al compilatorului nu trebuie neglijat, iar sistemul de ajutor al Borland Pascal 7.0 este foarte bine pus la punct. A se folosi cu incredere Exemplu de folosire a catorva functii: Line number On/Off | Expand/Contract | Select all 1. var caracter: Char; 2. index: Byte; 3. cosinus: Real; 4. putere: Longint; 5. begin 6. WriteLn(Chr(97)); {va afisa litera a (mica)} 7. WriteLn(Ord('a')); {va afisa 97} 8. cosinus := cos(3.1415926535897932); {ar trebui ca valoarea sa fie egala cu 0} 9. WriteLn(cosinus); {si afisam 0} 10. putere := Sqr(5); {5 la patrat = 125}
11. 12.
WriteLn(putere); end.
Formatarea
afisarii
Formatarea afisarii presupune afisarea datelor (cu functiile Write sau WriteLn) care le dorim in alta forma. Contine mai multe cazuri si metode de folosire. Despre formatarea afisarii am vorbit, pe scurt, si in tutorialul anterior de Pascal. Afisarea normala este o afisare ca in exemplul de mai jos. Line number On/Off | Expand/Contract | Select all 1. WriteLn('Acesta este un test de afisare.'); Sa trecem la formatari. 1. Prima metoda de formatare este de folos cand dorim sa aliniem la dreapta textul carel vrem afisat. Se foloseste afisand in felul urmator: Line number On/Off | Expand/Contract | Select all 1. WriteLn('Text de afisat' : 40); De remarcat secventa : 40. Aceasta secventa specifica pe cate pozitii va fi afisat textul, aliniind textul la dreapta. Daca am vrea sa afisam "bitcell.info" (care contine 12 caractere) pe 20 de pozitii, afisarea va fi facuta punand 8 spatii (20 - 12) si apoi scriind textul. Daca numarul de pozitii specificat este prea mic, el este ignorat si afisarea se executa ca o afisare normala. Acest tip de afisare poate fi de folos, de exemplu, cand vrem sa cream un meniu. 2. A doua metoda de formatare a afisarii presupune dublarea secventei care specifica numarul de pozitii pe care se face afisarea, ca in exemplul de mai jos: Line number On/Off | Expand/Contract | Select all 1. WriteLn(40.234111242:5:2); Acest tip de formatare se foloseste doar pentru afisarea numerelor reale. Mergand pe exemplul de mai sus, secventa :2 specifica numarul de zecimale afisat, iar :5 specifica numarul total de pozitii pe care va fi afisat numarul, incluzand punctul zecimal. Afisarea se va face normal, afisand "40.23" (sunt 5 caractere, deci nu se pune niciun fel de spatiu). Daca secventa :5 era, sa zicem :3, ea era ignorata. Operatii cu tipul logic (Boolean)
Pentru tipul logic de date exista cativa operatori, prezentati mai jos.
Operatori logici Operator not and or xor Descriere negatie conjunctie (si logic) disjunctie (ori logic) disjunctie exclusiva
Tabelurile de adevar pentru operatorii AND, OR si XOR sunt date mai jos (negatia nu cred sa aiba nevoie de tabel).
Tabele de adevar True False OR True True True False True False
Operatorii relationali care pot fi folositi pentru a genera rezultate logice (de tip Boolean True sau False), sunt mai jos.
Operatori relationali Operator < > = <= >= <> Descriere mai mic mai mare egal mai mic sau egal mai mare sau egal diferit
Pe cat posibil, evitati folosirea operatorul de egalitate ( = ) cand vreti sa comparati numere reale. Mici erori de rotunjire pot genera erori destul de mari (1.5678 este diferit de 1.5679). De tinut minte este faptul ca operatorii folositi in Pascal au, fiecare, o anumita prioritate, care permite compilatorului sa "inteleaga" intern ordinea operatiilor.
Nivel 0 1 2 3
Prioritatea operatorilor Operatori not * / div mod and + - or < > <= >= = <>
prioritate minima
Daca vreti sa fiti siguri ca ordinea operatiilor este cea dorita de dvs., va trebui sa-i explicati compilatorului acest lucru, punand paranteze, ca in matematica. Atentie: in cazul folosirii operatorilor relationali intr-o expresie logica, este indicat ca fiecare sub-expresie sa fie pusa in interiorul unui set de paranteze, datorita prioritatilor expuse mai sus. Exemplu de folosire a operatorilor relationali si logici: Line number On/Off | Expand/Contract | Select all 1. var numar: integer; 2. carac: char; 3. begin 4. carac := 'd';
5. numar := 5; 6. if (carac = 'D') then 7. Writeln('Caracterul este D'); 8. 9. if (carac = 'a') and (numar = 5) then 10. WriteLn('Caracter = a, numar = 5'); 11. 12. if (carac = 'a') or (numar = 5) then 13. WriteLn('Caracter = a SAU numar = 5'); 14. end. Sper ca ati inteles faptul ca acest cod va afisa doar Line number On/Off | Expand/Contract | Select all 1. Caracter = a SAU numar = 5
6. readln; 7. end. O variabila de tip string este stocata intern pe 256 de bytes. Motivul pentru acest lucru este faptul ca pe pozitia 0 din acest sir este stocata lungimea sirului (spre deosebire de C / C++, unde caracterul 0 din ASCII este terminator de sir). Avand in vedere ca numarul maxim de valori care le poate lua un byte este de 256 (intre 0 si 255), ar trebui sa fie clar de ce tipul string poate stoca maxim 255 de caractere (aceasta limitare se refera la Borland Pascal - in alte variante de Pascal sau in Delphi, aceasta limita este ridicata la peste 2 miliarde de caractere).
Nume
Functii si proceduri utilizate pentru tipul string Descriere Aceasta functie returneaza lungimea, in caractere, a variabilei de tip string. Primul caracter (cel de pe pozitia 0 - care specifica lungimea stringului) nu este luat in calcul. Format apel: Line number On/Off | Expand/Contract | Select all 1. Length(S: String) Returneaza un string care contine caracterele specificate din string-ul introdus ca parametru. Format apel: Line number On/Off | Expand/Contract | Select all 1. Copy(S: string; Index: Integer; Count: Integer);
Length
Copy Stringul rezultat va contine Count caractere, incepand de la pozitia Index inclusiv, din stringul S. Daca Index specifica un numar mai mare decat lungimea totala a stringului, atunci stringul rezultat va fi vid. Daca numarul specificat de Count trece de numarul de caractere totale, incepand de la Index, se va returna tot stringul de la pozitia Index pana la final. Concateneaza mai multe stringuri intr-unul singur. Returneaza stringul rezultat. Format apel: Line number On/Off | Expand/Contract | Select all 1. Concat(s1 [, s2, ..., sn]: String); Concat Alternativ, stringurile pot fi concatenate folosind operatorul +, ca la operatia de adunare. Daca stringul rezultat are mai mult de 255 de caractere, este trunchiat la primele 255 de caractere. Procedura care sterge un subsir de caractere dintr-un string. Format apel: Line number On/Off | Expand/Contract | Select all 1. Delete(var S: String; Index: Integer; Count: Integer);
Delete
Din stringul S vor fi sterse Count caractere, incepand cu pozitia Index. Daca Index este mai mare decat lungimea totala stringului, procedura nu avea avea nici un efect. Daca numarul specificat de Count trece de numarul de caractere total, incepand de la Index,
Functii si proceduri utilizate pentru tipul string stringul va fi trunchiat incepand cu pozitia Index. Insereaza un substring intr-un string. Format apel: Line number On/Off | Expand/Contract | Select all 1. Insert(Source: String; var S: String; Index: Integer); Insert
Stringul Source va fi inserat in stringul S, incepand de la pozitia Index. Daca sirul rezultat va avea mai mult de 255 de caractere, va fi trunchiat la 255 de caractere. Cauta pozitia unui subsir intr-un string, returnand pozitia primului caracter al subsirului din sir. Format apel: Pos Line number On/Off | Expand/Contract | Select all 1. Pos(SubStr: String; S: String): Byte;
limita inferioara trebuie sa fie mai mica decat limita superioara, ca valori acest tip nu poate fi declarat decat folosind valori ordinale
Exemple: Line number On/Off | Expand/Contract | Select all 1. type 2. litere_mari = 'A' .. 'Z'; 3. litere_mici = #97 .. chr(122); {metode alternative de introdus caracter} 4. {functioneaza doar din cod !} 5. note = 1 .. 10; Tipul multime (set) Multimile exista peste tot in jurul nostru, iar Pascal ne ofera posibilitatea de a lucru cu ele. Multimele sunt un mod de a clasifica tipuri comune in grupuri. Ca un exemplu din viata, imaginati-va un buchet cu flori de mai multe feluri : o multime de flori In Pascal, multimile sunt gandite ca avand niste valori dintr-un subdomeniu definit. O multime poate avea una, mai multe sau toate valorile din subdomeniul respectiv. Subdomeniul insusi este denumitmultimea de baza, multimea din care orice multime de acelasi tip isi poate lua valori. Declarare tip: Line number On/Off | Expand/Contract | Select all 1. type multime = set of 1 .. 10; 2. multime_byte = set of byte; Dupa cum observam, multimile pot fi definite ca avand un subdomeniu de valori sau toate valorile unui anumit tip (ordinal), avand ca restrictie un numar total de maxim 256 de valori distincte.
Un program demonstrativ pentru multimi: 1. type multime = set of 1..10; 2. var n_prime, n_pare: multime; {numere prime mai mici decat 10} 3. i: byte; 4. begin 5. n_prime := [2, 3, 5, 7]; 6. n_pare := [2, 4, 6, 8]; 7. 8. Write('Numere prime: '); 9. for i := 1 to 10 do 10. if (i in n_prime) then {apartenenta} 11. write(i : 3); 12. WriteLn; 13. 14. n_prime := n_prime + [10]; {reuniune} 15. {acum multimea va contine si numarul 6} 16. 17. n_prime := n_prime + n_pare; {reuniune - again} 18. n_prime := n_prime - [5, 7]; {diferenta} 19.
20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34.
Write('Numere ramase in multime (reuniune, diferenta): '); for i := 1 to 10 do if (i in n_prime) then {apartenenta} write(i : 3); WriteLn; n_prime := n_pare * [2, 3, 6, 9]; {intersectie} Write('Numere ramase in multime (intersectie): '); for i := 1 to 10 do if (i in n_prime) then {apartenenta} write(i : 3); WriteLn; ReadLn; end.
Tipul enumerare Tipul subdomeniu, explicat mai sus, spune cum putem da note fara sa avem posibilitatea de a da nota 11 ... sau 0. Din pacate, am auzit ca de vreo cativa ani se dau calificative, cel putin pentru elevii claselor primare. Hai sa vedem ce tip de data am putea folosi pentru a stoca niste calificative. Tipul enumerare ofera posibilitatea definirii unui tip ordinal de data, creand si identificatori pentru posibilele valori. Declarare tip: Line number On/Off | Expand/Contract | Select all 1. type nume_tip : (ident1 [, ident2, ... identX]); Fiecare valoare din lista unui tip enumerate are asociat un numar ordinal (primul are valoarea 0), iar variabilelor de acest tip li se pot aplica functiile aplicabile tipurilor ordinale, mai putin Chr. Un exemplu de cod care foloseste tipul enumerat: Line number On/Off | Expand/Contract | Select all 1. type 2. zile = (luni, marti, miercuri, joi, vineri, sambata, duminica); 3. calificative = (foarte_rau, rau, suficient, bun, foarte_bun, grozav); 4. var zi: zile; 5. nota: calificative; 6. begin 7. zi := vineri; 8. zi := succ(zi); {acum e sambata} 9. 10. zi := pred(miercuri); {tocmai a devenit marti} 11. WriteLn('Numarul de ordine pentru Marti este ', Ord(marti), '.'); 12. nota := rau; 13. Write('Numarul de ordine pentru "rau" este ', Ord(nota), '.'); 14. ReadLn;
15.
end.
Restrictii: identificatorii nu pot fi dublati pe parcursul unui program. identificatorii nu pot fi afisati de Pascal (identificatorul nu are o valoare text pentru compilatorul Pascal) Tipul record Cum am vazut deja la tipul string, si cum vom mai vedea la array-uri, exista posibilitati de a stoca in memorie cantitati mari de date, cu elemente de acelasi tip. Ce se intampla in cazul in care vreau sa stochez mai multe tipuri de date intr-un singur element ? Un caz concret ar fi varstele unor oameni. Avem nevoie de un loc pentru nume si de un loc pentru varsta ... o variabila string si o variabila byte. Tipul record (inregistrare) permite crearea unui tip de date care sa permita gruparea unor date de tipuri diferite. Declararea unui tip inregistrare: 1. uses crt; 2. type 3. nume_tip = record 4. field1: string; 5. field2: byte; 6. field3: integer 7. ... 8. fieldX: tipX; 9. end; TipX nu este un tip implicit al Pascal, sper ca e destul de clar. Ideea principala este ca tipul inregistrare poate contine mai multe campuri cu valori de diferite tipuri. Program care sa citeasca si sa afiseze numele si varstele a doua persoane. 1. uses crt; 2. type 3. persoana = record {tip inregistrare, definit de noi} 4. nume: String; 5. varsta: Byte; 6. end; 7. 8. var first, second: persoana; {tipul nostru inregistrare} 9. begin 10. ClrScr; 11. 12. Write('Dati numele primei persoane: '); 13. ReadLn(first.nume); 14. Write('Dati varsta primei persoane: '); 15. ReadLn(first.varsta); 16. 17. Write('Dati numele celei de-a doua persoane:'); 18. ReadLn(second.nume); 19. Write('Dati varsta celei de-a doua persoane: '); 20. ReadLn(second.varsta);
21. 22. ClrScr; 23. WriteLn('1. first.varsta, ' 24. WriteLn('2. second.varsta, ' 25. ReadKey; 26. end.
Nume: ', first.nume, ' - varsta: ', de ani.'); Nume: ', second.nume, ' - varsta: ', de ani.');
O alta posibilitate oferita de tipul inregistrare este faptul ca pot avea o parte variabila, dar, in afara de a incurca treburile, nu i-am gasit nicio alta utilitate, motiv pentru care nu o voi explica aici.