• Non ci sono risultati.

Introduzione al Pascal

N/A
N/A
Protected

Academic year: 2021

Condividi "Introduzione al Pascal"

Copied!
19
0
0

Testo completo

(1)

Introduzione al Pascal

Dott. Simone Zuccher 3 aprile 2007

Blaise Pascal

Clermont-Ferrand, Puy-de-Dˆome, Francia, 19 giugno 1623 – Parigi, 19 agosto, 1662.

Fu matematico, fisico, filosofo e religioso.

(2)

Indice

1 Introduzione 1

1.1 Che cos’`e il Pascal? . . . 1

1.2 Storia del Pascal . . . 1

1.3 Compilatori: il GNU Pascal . . . 2

1.3.1 Turbo Pascal . . . 3

1.3.2 Delphi . . . 3

1.4 Perch´e il Pascal? . . . 4

2 Elementi base di un programma in Pascal 4 2.1 Il classico “Hello World!” . . . 4

2.2 Struttura di un programma in Pascal . . . 5

2.3 Parole riservate . . . 6

2.4 Identificatori . . . 6

2.5 Variabili e tipi . . . 7

2.6 Costanti e variabili . . . 8

2.6.1 Assegnazione di variabili . . . 8

2.7 Dati di tipo numerico . . . 8

2.8 Dati di tipo char e stringhe . . . 10

2.9 Dati di tipo boolean . . . 11

2.10 Input ed output di base (read e write) . . . 12

Elenco delle figure

1 Codice ASCII. . . 16

2 Codice ASCII esteso. . . 17

Elenco delle tabelle

1 Tabella delle parole riservate . . . 6

2 Elenco dei tipi di dati primitivi in Pascal. . . 7

3 Tabella degli operatori artimetici sul tipo integer. . . 9

4 Tabella degli operatori artimetici sul tipo real. . . 10

5 Tabella dell’operatore AND. . . 11

6 Tabella dell’operatore OR. . . 11

7 Tabella dell’operatore NOT. . . 12

8 Tabella degli operatori artimetici sul tipo boolean. . . 12

(3)

1 Introduzione

1.1 Che cos’` e il Pascal?

Il Pascal `e un linguaggio di programmazione ad alto livello, come per esempio il FOR- TRAN (scopi scientifici), il C (scopi industriali) e il Java (applicazioni con interfacce grafiche). Questo linguaggio di programmazione `e nato con lo scopo di essere utilizzato a fini didattici e non necessariamente per la realizzazione di software applicativi.

La programmazione in Pascal risulta semplice ed ordinata e “costringe” il program- matore a rispettare alcune regole che rendono il codice ben strutturato e di facile lettura.

Infatti, tutto ci`o che si utilizza deve essere dichiarato e quindi viene esclusa la possibi- lit`a di commettere errori di programmazione dovuti a digitazione errata dei nomi delle variabili (come potrebbe accadere in C e FORTRAN), perch´e il compilatore le rifiuta se non sono state dichiarate preventivamente.

Questa struttura ordinata e rigorosa `e uno degli aspetti fondamentali che rende il Pascal un ottimo linguaggio per imparare a programmare. Anzi, proprio queste limi- tazioni, che possono risultare noiose per un programmatore esperto, sono molti utili al

“programmatore in erba” in quanto forniscono una metodologia di programmazione cor- retta e rendono pi`u semplice l’individuazione di errori concettuali fatti nella scrittura del codice. Un altro punto a favore del Pascal come linguaggio didattico `e la semplicit`a con cui si scrive il codice, essendo le istruzioni del Pascal costituite da espressioni di tipo algebrico e da termini inglesi (dette parole riservate) come PROGRAM , BEGIN , END etc.

Uno svantaggio del linguaggio `e certamente la scarsa flessibilit`a che lo rende inadatto allo sviluppo di software applicativi.

1.2 Storia del Pascal

Il Pascal `e stato sviluppato all’inizio degli anni ’70 da Niklaus Wirth del Politecnico di Zurigo con lo scopo di realizzare un linguaggio ad alto livello orientato all’insegnamento della programmazione strutturata.

Il linguaggio sviluppato da Wirth viene a volte definito Pascal standard, in realt`a in seguito lo standard del linguaggio `e stato definito dall’American National Standards Institute (ANSI), quindi spesso si parla di Pascal ANSI. I compilatori disponibili oggi aderiscono perfettamente allo standard ANSI, ma sempre vengono fatte delle aggiunte che rendono la programmazione migliore, anche se non sempre sono compatibili con altri compilatori.

Attualmente sono disponibili diversi compilatori, free software e non, ma sicuramente il compilatore pi`u famoso `e il Turbo Pascal creato nel 1983 dalla Borland.

L’evoluzione dell’informatica ha apportato anche al Pascal alcune modifiche: ini- zialmente il Pascal supportava la programmazione strutturata, oggi supporta anche la programmazione orientata agli oggetti (OOP Object Oriented Programming); la nascita di ambienti di sviluppo visuali ha dato vita al Delphi, che viene utilizzato anche nello sviluppo di software applicativi.

Oggi il Pascal viene ampiamente impiegato nel campo per cui era stato creato e cio`e

(4)

la didattica, ma non viene utilizzato per la produzione di applicazioni, dove vengono preferiti linguaggi “industriali” quali il C.

1.3 Compilatori: il GNU Pascal

Sono molti i compilatori disponibili. Viene qui presentato unicamente GNU-Pascal, essendo esso disponibile gratuitamente sotto Linux.

I pregi dello GNU Pascal sono essenzialmente una perfetta aderenza allo standard A.N.S.I., una buona velocit`a, e tutte le altre caratteristiche che rendono unici i compilato- ri GNU. Per contro, la quantit`a di librerie che vengono fornite con questo compilatore non

`e molto estesa. Un’altra nota dolente `e la mancanza della possibilit`a di scrivere codice assembly integrato all’interno del codice Pascal, cosa che altri compilatori consentono.

Naturalmente questo compilatore `e fornito con licenza GPL (www.gnu.org), altri- menti non sarebbe GNU, ed inoltre esistono dei porting per altre piattaforme tra cui DOS e Win32.

Il nome del comando per i sistemi Linux `e gpc.

Per avere un’idea sull’utilizzo del compilatore basta eseguire man gpc oppure, per la distribuzione Debian, gpc --help

$man gpc

GPC(1) GNU Tools GPC(1)

NAME

gpc - GNU project Pascal Compiler (v2.0) SYNOPSIS

gpc [option | filename ]...

...

...

...

gpc --help

Usage: gpc [options] file...

Options:

-pass-exit-codes Exit with highest error code from a phase

--help Display this information

--target-help Display target specific command line options (Use ’-v --help’ to display command line options of sub-processes) -dumpspecs Display all of the built in spec strings -dumpversion Display the version of the compiler -dumpmachine Display the compiler’s target processor

-print-search-dirs Display the directories in the compiler’s search path -print-libgcc-file-name -print-file-name=<lib> Display the full path to library <lib>

-print-prog-name=<prog> Display the full path to compiler component <prog>

-print-multi-directory Display the root directory for versions of libgcc

(5)

-print-multi-lib Display the mapping between command line options and multiple library search directories

-print-multi-os-directory Display the relative path to OS libraries

-Wa,<options> Pass comma-separated <options> on to the assembler

-Wp,<options> Pass comma-separated <options> on to the preprocessor -Wl,<options>

-Xassembler <arg> Pass <arg> on to the assembler -Xpreprocessor <arg> Pass <arg> on to the preprocessor -Xlinker <arg> Pass <arg> on to the linker

-save-temps Do not delete intermediate files

-pipe Use pipes rather than intermediate files -time Time the execution of each subprocess

-specs=<file> Override built-in specs with the contents of <file>

-std=<standard> Assume that the input sources are for <standard>

-B <directory> Add <directory> to the compiler’s search paths -b <machine> Run gcc for target <machine>, if installed -V <version> Run gcc version number <version>, if installed

-v Display the programs invoked by the compiler

-### Like -v but options quoted and commands not executed -E Preprocess only; do not compile, assemble or link

-S Compile only; do not assemble or link

-c Compile and assemble, but do not link

-o <file> Place the output into <file>

-x <language> Specify the language of the following input files Permissible languages include: Pascal c c++ none

’none’ means revert to the default behavior of guessing the language based on the file’s extension Options starting with -g, -f, -m, -O, -W, or --param are automatically

passed on to the various sub-processes invoked by gpc. In order to pass other options on to these processes the -W<letter> options must be used.

For bug reporting instructions, please see:

<URL:http://www.gnu-Pascal.de/todo.html>.

1.3.1 Turbo Pascal

Parlando di Pascal non si pu`o non parlare del Turbo Pascal. Il Turbo Pascal `e un compilatore prodotto dalla Borland che grazie alla sua semplicit`a, potenza e velocit`a `e diventato “IL” compilatore Pascal. Le innovazioni introdotte dalla Borland oggi sono diventate degli standard, e molti compilatori si preoccupano di essere compatibili con il turbo Pascal. Purtroppo questo compilatore `e disponibile solo per DOS ed `e un software commerciale.

1.3.2 Delphi

Delphi `e un ambiente di sviluppo visuale molto potente e veloce. Il linguaggio usato dal Delphi `e sostanzialmente il Pascal con delle aggiunte (tipo OOP) che lo rendono pi`u potente e flessibile.

(6)

Anche Delphi `e un software commerciale prodotto dalla Borland ed `e disponibile per Windows. Da un po’ di tempo ne esiste una versione anche per Linux, Kylix, che non

`e free software ma che `e comunque disponibile gratuitamente se viene utilizzato per lo sviluppo di software libero.

1.4 Perch´ e il Pascal?

Il motivo principale che spinge all’uso del Pascal `e semplicemente la voglia di imparare a programmare, la semplicit`a di utilizzo, la rigorosit`a dell’impostazione. Tutti questi fat- tori rendono il Pascal uno dei migliori linguaggi disponibili per imparare a programmare come si deve.

Un secondo motivo `e la possibilit`a di passare a programmare in Delphi in maniera semplice e naturale, consentendo cos`ı la realizzazione di software ad un livello molto alto.

Il terzo motivo per scegliere il Pascal `e per la realizzazione di applicazioni destinate ad un uso personale o che non necessitano di prestazioni al top, evitando di complicarsi la vita con linguaggi pi`u difficili quali il C.

Solitamente il Pascal `e solo il primo di una serie di linguaggi di programmazione, come `e stato per l’autore. Tuttavia, il rigore del Pascal consente di non trovare grosse difficolt`a quando si passa a linguaggi pi`u complessi come il C.

2 Elementi base di un programma in Pascal

2.1 Il classico “Hello World!”

Il primo programma che ciascun programmatore scrive per vedere se ha capito i rudimenti di un linguaggio `e il classico “Hello World!”:

(1) (*Programma HelloWorld*) (2) program HelloWorld;

(3) begin

(4) writeln(’Hello World!’);

(5) end.

Analizziamo il programma riga per riga.

Alla riga 1 si trova un commento. Il testo scritto tra (* *) viene visto dal compilatore come un commento e non viene considerato ai fini della compilazione.

La riga 2 indica l’inizio del programma con la parola chiave program e dove “Hel- loWorld” rappresenta il nome del nostro programma.

Le righe 3 e 5 indicano l’inizio del blocco principale del programma, tra le parole chiave begin end vanno inserite le instruzioni che verranno eseguite

La riga 4 stampa a video la stringa ’Hello World’, il comando writeln(’testo da stampare’);

scrive a video tutto quello che si trova tra gli apici.

Dopo aver salvato le 5 righe di codice nel file hello.pas, si compili il programma eseguendo semplicemente

$ gpc -o hello hello.pas

(7)

Se il programma non contiene errori, nella stessa directory di hello.pas si trova il file eseguibile hello. Si noti che l’opzione -o seguita da hello ordina al compilatore di generare un file di output (da cui -o) di nome hello. Nel caso questa opzione venga omessa il nome di default per l’eseguibile `e a.out.

2.2 Struttura di un programma in Pascal

Un programma Pascal si divide generalmente in tre parti: Intestazione, Blocco delle dichiarazioni e Blocco delle istruzioni.

L’intestazione comincia con la parola chiave program seguita dal nome del program- ma e terminata da un punto e virgola ;:

program <nome_programma>;

Il blocco delle dichiarazioni definisce i vari dati che si usano nel programma e si pu`o suddividere nel seguente modo:

1. Etichette ( Label );

2. Costanti ( Const );

3. Tipi di dato definiti dall’utente ( Type );

4. Variabili ( Var );

5. Procedure e Funzioni ( Procedure e Function );

In seguito questi concetti saranno pi`u chiari, per ora ci si limita a dare una visione generale del blocco dichiarativo.

Il blocco delle istruzioni contiene le istruzioni che il programma deve eseguire al fine di produrre un’azione (quale pu`o essere il calcolo di un’operazione o la scritta di un testo a video).

Riepilogando, questa la struttura di un programma Pascal `e la seguente:

1. Intestazione;

2. Dichiarazioni;

(a) Label;

(b) Const;

(c) Type;

(d) Var;

(e) Procedure e Function;

3. Istruzioni;

Visto dal punto di vista della codice abbiamo :

(8)

(*Intestazione*)

program nome_programma;

(*Blocco delle dichiarazioni*) label L1,L2.... Ln;

const ... ; type ... ; var ... ; procedure ... ; function ... ;

(*Blocco delle istruzioni*) begin

(*Istruzioni*) end.

(*Fine del programma*)

Si noti che non `e possibile mettere la parte delle istruzioni prima di quella delle dichiarazioni (per ovvi motivi), mentre `e possibile invertire l’ordine di alcuni elementi nella parte dichiarativa. Tuttavia, `e consiglibile non farlo. Per imparare a memoria l’ordine delle varie parti si pu`o ricorrere alla frasetta La Cosa Tre Volte Pi`u Facile, in cui ogni iniziale corrisponde ad un elemento della parte dichiarativa nell’ordine corretto.

2.3 Parole riservate

Ogni linguaggio ha una serie di parole riservate che servono per scopi precisi e che il programmatore non pu`o in alcun modo ridefinire per i suoi scopi.

In tabella 1`e riportata la lista completa delle parole riservate del Pascal A.N.S.I.

AND ARRAY BEGIN CASE

CONST DIV DO DOWNTO

ELSE END FILE FOR

FORWARD FUNCTION GOTO IF

IN LABEL MOD NIL

NOT OF OR PACKED

PROCEDURE PROGRAM RECORD REPEAT

SET THEN TO TYPE

UNTIL VAR WHILE WITH

Tabella 1: Tabella delle parole riservate

2.4 Identificatori

Un identificatore `e il nome che si assegna ad una parte di un programma Pascal, per esempio una variabile, una costante, una funzione etc.

Un identificare deve rispettare le seguenti semplici regole:

(9)

1. Essere costituito da una sequenza qualsiasi di lettere e cifre, purch´e il primo ca- rattere sia una lettera. Non c’`e differenza tra maiuscole e minuscole in quanto il Pascal non `e case-sensitive, cio`e non distingue tra maiuscole e minuscole.

2. Non sono ammessi caratteri diversi da lettere o numeri (si noti che il simbolo underscore ‘_’ `e ammesso, mentre ovviamente il simbolo meno ‘-’ non lo `e.

3. Non `e possibile usare un parola riservata come identificatore.

4. Non sono ammessi gli spazi.

Vediamo ora alcuni esempi per chiarire meglio.

Pippo Pippo21 Pippo34 Pippo_56sono degli identificatori validi, inoltre per quan- to detto prima PIPPO pippo Pippo sono tutti lo stesso identificatore. 12Pippo non `e valido in quanto inizia con un numero. P/ippo non `e valido in quanto contiene il ca- rattere / che non `e n´e lettera n´e numero. Var non `e valido in quanto `e una parola riservata.

2.5 Variabili e tipi

I tipi di dati elementari del linguaggio Pascal dipendono dal compilatore utilizzato e dal- l’architettura dell’elaboratore sottostante. I tipi standard del Pascal ANSI sono elencati nella tabella 2. Il tipo ‘char’, non fa parte dello standard ANSI, ma `e molto diffuso e quindi viene incluso in quella tabella.

Tipo Descrizione

int Numeri interi positivi e negativi.

byte Interi positivi di un solo byte (da 0 a 255).

real Numeri a virgola mobile.

boolean Valori logici booleani.

char Carattere (generalmente di 8 bit).

Tabella 2: Elenco dei tipi di dati primitivi in Pascal.

Ogni tipo di variabile pu`o contenere un solo tipo di dati, esprimibile eventualmente attraverso una costante letterale scritta secondo una forma adatta.

I valori numerici vengono espressi da costanti letterali senza simboli di delimitazione.

Gli interi (integer) vanno espressi con numeri normali, senza punti di separazione di un’ipotetica parte decimale, prefissati eventualmente dal segno meno (-) nel caso di valori negativi.

I valori byte vanno espressi come gli interi positivi, con la limitazione della dimensione massima.

I numeri reali (real) possono essere espressi come numeri aventi una parte decimale, segnalata dalla presenza di un punto decimale. Se si vuole indicare un numero reale corrispondente a un numero intero, si deve aggiungere un decimale finto, per esempio, il numero 10 si pu`o rappresentare come 10.0. Naturalmente `e ammessa anche la notazione esponenziale. Quindi, per esempio, 7e-2 corrisponde a 7 · 10−2, pari a 0.07.

(10)

I valori logici (boolean) vengono espressi dalle costanti letterali TRUE e FALSE.

I valori carattere (char) e stringa (string), vengono delimitati da coppie di apici singoli, come ’A’, ’B’, ... ’Hello World!’.

2.6 Costanti e variabili

Una costante, come dice la parola, `e un oggetto che rimane sempre con lo stesso valore per tutta la durata del programma.

La struttura per dichiarare una costante `e la seguente:

const <identificatore> = <valore>;

Es. const GiorniSettimana = 7;

Es. const Ore = 24;

Le variabili possono essere viste come degli oggetti che possono contenere un dato, os- sia un contenitore. Chiaramente il valore del dato pu`o cambiare nel corso del programma purch´e il tipo rimanga sempre uguale.

Le varibili vanno dichiarate nel seguente modo:

var <identificatore1>,<indenticatore2> : <tipo di dato>;

Es. var Nome:string;

Es. var NumeroIntero: integer;

Altri esempi:

var conta : integer;dichiara la variabile ‘conta’ di tipo intero.

var conta,canta : integer; dichiara le variabili ‘conta’ e ‘canta’ di tipo intero.

var conta : integer;

canta : integer;

sono esattamente uguali all’esempio precedente.

Per dichiarare la variabile conta di tipo intero, e la variabile lettera di tipo carattere:

var

conta : integer;

lettera : char;

2.6.1 Assegnazione di variabili

Per assegnare un valore ad una certa variabile si utilizza l’operatore di assegnamento

“:=”, la cui sintassi `e la seguente:

<nome variabile> := <espessione o valore>;

Naturalmente l’espressione o il valore devono essere dello stesso tipo della variabile.

2.7 Dati di tipo numerico

I dati numerici si dividono in due tipi: numeri interi e numeri reali. I dati interi sono i numeri interi (con segno), a questo gruppo appartengono varibili, costanti e funzioni che producono numeri interi, il tipo intero in Pascal viene indicato con la parola chiave

(11)

Operatore Scopo Operandi Risultato

+ Addizione integer integer

- Sottrazione integer integer

* Moltiplicazione integer integer

/ Divisione integer real

DIV Divisione intera (con resto) integer integer MOD Resto della divisione intera integer integer Tabella 3: Tabella degli operatori artimetici sul tipo integer.

integer. Gli operatori artimetici che possono lavorare sugli interi sono riportati in tabella 3.

Il seguente programma mostra come si dichiarano le variabili di tipo integer e come si usano gli operatori appena visti.

program ProvaInteger;

(*Fase di dichiarazione*) var A,B,C,D: integer;

R:Real;

begin

(* Assegnazione*) A:=12;

B:=23;

C:=-25;

(*Operazioni Aritmetiche*) D:=A+C; (*12-25= -13*) D:=B-C; (*23+25= 48*)

D:=B DIV 2; (*23 div 2 = 11 con resto 1*) D:=B MOD 2 ; (*1 e’ il resto di 23:2*) R:=B / 2 ; (*11.5*)

end.

I dati reali sono i numeri reali (con segno). A questo gruppo appartengono varibili, costanti e funzioni che producono numeri reali. Il tipo in Pascal viene indicato con l’identificatore real.

Gli operatori artimetici che possono lavorare su dati real sono riportati in tabella 4.

(12)

Operatore Scopo Operandi Risultato

+ Addizione real real

- Sottrazione real real

* Moltiplicazione real real

/ Divisione real real

Tabella 4: Tabella degli operatori artimetici sul tipo real.

2.8 Dati di tipo char e stringhe

I dati di tipo char, come indica la parola, sono i caratteri cio`e stringhe di un solo carattere. I caratteri ammessi sono i caratteri del codice A.S.C.I.I. standard (vedi tabella in figura 1, pagina 16, per il codice standard e 2, pagina 17, per il codice esteso). Il seguente programma mostra come si dichiarano le variabili di tipo char e come si usa il codice A.S.C.I.I.

program ProvaRealChar;

var a,b,c : real;

d,e: char;

ascii:integer;

begin a:=23.4;

b:=0.344E2; (*0.344 x 10^2 = 34.4*) c:=a+b;

c:=a-b;

c:=a*b;

c:=a/b;

d:=’d’;

d:=’3’;

e:=’r’;

e:=’A’;

e:=char (65); (*la funzione char restituisce il carattere corrispondente al codice ascii inserito in questo caso ’A’ = ascii 65 *)

ascii:=ord(’A’); (*opposta a char da 65*) writeln(e,’ ’,ascii);

end.

Si noti l’uso della funzione char(integer)che restituisce il carattere corrispondente al codice A.S.C.I.I passato come parametro. La funzione opposta a char(integer) `e ord(char), che restituisce il valore numerico corrispondente al codice ascii del carattere passato come parametro.

Le stringhe di caratteri in Pascal rappresentano un tipo di dato proprio del linguaggio che viene indicato con la parola riservata string. Una variabile di tipo string pu`o contene al massimo una stringa di 255 caratteri. Tra i dati di tipo string intervengono

(13)

diverse funzioni e anche l’operatore “+” detto operatore di concatenazione, che non fa altro che fondere pi`u stringhe in una sola. Il seguente programma mostra come si dichiarano le variabili di tipo string ed alcuni usi.

program ProvaStringhe;

var S1,S2,S3:string;

begin

S1:=’Rossi’;

S2:=’’; (*stringa vuota*)

S3:=’Carlo’; S2:=S3 + ’ ’ + S1; (* S2=’Carlo Rossi’*) writeln(S1,’ ’,S2,’ ’,S3,’ ’);

end.

E inoltre possibile definire stringhe con ampiezza massima minore di 255 usando il se-` guente indentificatore: string[dimensione_massima]. Per esempio, var S: string[12];

definisce una stringa con valore massimo 12 caratteri.

2.9 Dati di tipo boolean

Diciamo che i valori booleani sono dei valori di verit`a, vero e falso in italiano, true e false in inglese oppure on e off, oppure 0 e 1. Una espressione booleana assume questi valori in seguito ad una operazione logica quale pu`o essere un confronto.

Su un dato booleano intervengono tre opeazioni fondamentali: and, or e not. Queste operazioni agiscono su dati booleani e restituiscono sempre un dato booleano.

Vediamo qui di seguito come funzionano queste operazioni (usiamo la denominazione inglese True e False per indicare i valori booleani)

AND True False

True T F

False F F

Tabella 5: Tabella dell’operatore AND.

OR True False

True T T

False T F

Tabella 6: Tabella dell’operatore OR.

Come si vede and (tabella 5) resituisce il valore true solo quando entrambi gli ope- randi sono true, mentre l’operazione or (vedi tabella 6) restituisce false solo quando riceve due false in ingresso. Il not (vedi tabella 7), invece, non fa altro che invertire il valore passato (negazione).

Il tutto si pu`o anche immaginare come numeri binari true=1 e false=0 e le operazione and come moltiplicazione binaria e or come somma binaria.

Un’operazione che restituisce un valore booleano `e il confronto. Per esempio:

(14)

NOT

T F

F T

Tabella 7: Tabella dell’operatore NOT.

(12 < 10) (*Restituisce False*) (12 > 10) (*Restituisce True*)

(12 >10) AND (3 < 1) (*Restituisce True*)

In Pascal i valori booleani formano un vero e propio tipo di dato contrassegnato dall’indentificatore boolean.

Gli operatori and or not intervengono su questi tipi di dati e le operazioni sono combinate per mezzo di parentesi ().

Gli operatori che possono lavorare su dati booleani sono riportati in tabella 8.

Significato Operatore

Maggiore >

Maggiore o uguale >=

Minore <

Minore o uguale >=

Uguale =

Diverso <>

Tabella 8: Tabella degli operatori artimetici sul tipo boolean.

Di seguito viene riportato un esempio sull’utilizzo di dati booleani.

program ProvaBoolean;

var A,B,C: Boolean;

begin

A:=(12<15); (*vero*) writeln(’12<15? A=’,A);

B:=(12<10); (*falso*) writeln(’12<10? B=’,B);

writeln(’A AND B: ’, (A AND B));

writeln(’A OR B: ’, (A OR B));

writeln(’NOT(A AND B): ’, (NOT(A AND B)));

end.

2.10 Input ed output di base (read e write)

Il comando read (read(<lista della variabili>)) prende come parametri delle va- riabili, anche una solamente, legge quello che l’utente ha scritto da tastiera non appena viene premuto invio, e lo assegna alla lista delle variabili. I tipi di variabili leciti sono

(15)

integer real char string. Ogni variabile della lista `e separata dell’altra mediante la virgola (“,”). Nel caso di pi`u variabili ci sono due possibilit`a di realizzare l’input. Una

`e di scrivere tutti i valori separati da uno spazio, l’altra di digitare invio dopo ogni dato.

Il comando write (write(<dati in uscita>)) stampa a video i dati che gli vengono passati come parametro. I dati leciti sono variabili, costanti e stringhe, separati dalla virgola.

Esistono due varianti di read e write che sono rispettivament writeln e readln.

Questi due comandi funzionano nello stesso modo di write e read, con l’unica differenza di portare il cursore su una nuova linea appena finito (ln sta appunto per “line”).

Il seguente codice dovrebbe far capire meglio l’uso di questi comandi.

program InputeOutput;

var i: integer;

r: real;

c: char;

s: string;

begin

writeln(’Ciao questo programma un esempio di Input e output’);

(*Scrive a video questa stringa e va a capo*) writeln; (*Stampa una riga vuota*)

write(’Inserisci un numero intero :’);

readln(i);

writeln(’Hai inserito : ’,i);

writeln;

write(’Inserisci un numero reale :’);

readln(r);

writeln(’Hai inserito ’,r);

(*r viene stampato nel formato esponenziale*)

writeln(’Hai inserito : ’,r:3:4);(*Dopo lo spieghiamo*) writeLn;

write(’Inserisci un carattere :’);

readln(c);

writeln(’Hai inserito : ’,c);

writeln;

write(’Inserisci una stringa :’);

readln(s);

writeln(’Hai inserito :’,s);

writeln;

(16)

write(’Inserimento multiplo di intero e reale :’);

readln(i,r);

writeln(’Hai inserito : ’,i,’ ’,r);

end.

Per stampare i numeri reali oltre la notazione esponenziale `e possibile utilizzare il comando write(r:X:Y), dove r `e il numero reale, x `e un numero naturale che indica quanto spazio deve occupare il numero scritto (numero di caratteri) mentre y indica il numero di cifre dopo la virgola (in questo caso se le cifre sono di pi`u verr`a effettuato un arrotondamento).

Nel caso dei comandi write e writeln `e quindi possibile formattare l’output inserendo lo spazio che un certo dato deve occupare sullo schermo. Per dire quanto spazio deve occupare un dato si usa, come visto, la variante <variabile>:<spazio> all’interno dei due comandi. Naturalmente se il dato necessita di pi`u spazio la formattazione viene ignorata. Nel caso in cui il dato richiede meno spazio, questo viene preservato e il dato viene allineato a destra. Il seguente programma riassume tali concetti.

program Formattazione;

var a1,a2,a3,a4,a5,a6: integer;

r1,r2,r3,r4,r5,r6: real;

begin

writeln(’Programma di esempio per la formattazione del testo’);

writeln;

writeln(’Testo non Formattato’);

a1:=10;

a2:=334;

a3:=2103;

a4:=0;

a5:=46;

a6:=555;

r1:=1.54;

r2:=22.3;

r3:=-34.45;

r4:=-r2;

r5:=r1*r1;

r6:=r5-r1;

writeln;

writeln(’Tabella:’);

writeln;

writeln(a1,’ ’,a2,’ ’,a3);

writeln(a4,’ ’,a5,’ ’,a6);

writeln;

writeln(r1,’ ’,r2,’ ’,r3);

writeln(r4,’ ’,r5,’ ’,r6);

writeln;

writeln(’Testo Formattato’);

(17)

writeln;

writeln(’Tabella:’);

(*Ogni dato occupa uno spazio di 16 colonne*) writeln; WriteLn(a1:16,a2:16,a3:16);

writeln(a4:16,a5:16,a6:16);

writeln;

WriteLn(r1:16:4,r2:16:4,r3:16:4);

WriteLn(r4:16:4,r5:16:4,r6:16:4);

end.

(18)

Figura 1: Codice ASCII.

(19)

Figura 2: Codice ASCII esteso.

Riferimenti

Documenti correlati

Nelle attività introduttive abbiamo incontrato alcune situazioni nelle quali i numeri naturali non sono più sufficienti. Essi formano l’insieme dei numeri interi relativi

Le tre seguenti successioni di numeri interi sono state scritte seguendo un preciso procedimento

Sulla retta numerica l’addizione di un numero positivo si rappresenta con uno spostamento in senso positivo, cioè verso destra. L’addizione di un numero negativo si

caratteristica molto interessante: ogni sottrazione con numeri interi relativi può essere trasformata in un'addizione. Ogni sottrazione in Z può essere trasformata in un’addizione

Chi formulava i programmi per i primi computers utilizzati disponeva solo dei codici binari delle istruzioni della macchina e doveva servirsi degli indirizzi fisici delle celle-m

[r]

Una funzione si dice discontinua se esiste almeno un punto del suo dominio dove la funzione non ` e continua.. Tipiche funzioni discontinue sono le funzioni che presentano dei

PER ADDIZIONE ALGEBRICA ( O SOMMA ALGEBRICA) SI INTENDE L’OPERAZIONE CHE PRENDE IN CONSIDERAZIONE SIA LA SOMMA CHE LA DIFFERENZA. NB: OGNI NUMERO INTERO PUO’ ESSERE