1 Tipi di dato modificabili §a livello semantico, riconduciamo la modificabilità alla nozione di variabile l lo stato “modificabile” corrispondente sarà.

Slides:



Advertisements
Presentazioni simili
Traduzione ed Interpretazione
Advertisements

Tipi di dato astratti Lista, Pila, Coda, Albero.
Estendere i linguaggi: i tipi di dato astratti
Linguaggi di programmazione
2/11/2004Laboratorio di Programmazione - Luca Tesei1 Punto della situazione Da dove veniamo, dove andiamo.
Type Checking (1° parte)
Algoritmi e Programmazione
Programmazione II Docente: Francesca Levi
1 Astrazioni sui dati : Specifica ed Implementazione di Tipi di Dato Astratti in Java.
1 Semantica Operazionale di un frammento di Java: lo stato.
Semantica Operazionale di un frammento di Java: lo stato
Generalità Linguaggio e Macchina Astratta
1 Strutture dati nel supporto a run time. 2 Entità presenti quando un programma va in esecuzione §programmi dutente (compilati) §routines del supporto.
LIP: 1 Marzo 2005 Classe Object e Vettori. Partiamo da Lesercizio dellultima esercitazione realizzato tramite array Vedremo come si puo fare in modo piu.
Fondamenti di Informatica I CDL in Ingegneria Elettronica - A.A CDL in Ingegneria Elettronica - A.A Strutture dati dinamiche.
Strutture dati elementari
Fondamenti di Informatica II Ingegneria Informatica / Automatica (A-I) Meccanica Prof. M.T. PAZIENZA a.a – 3° ciclo.
Informatica di base A.A. 2003/2004 Algoritmi e programmi
Laboratorio di Linguaggi lezione VIII Marco Tarini Università dellInsubria Facoltà di Scienze Matematiche, Fisiche e Naturali di Varese Corso di Laurea.
Introduzione alla programmazione lll
1 Implementazione di Linguaggi 2 Implementazione di Linguaggi 2 Federico Bernardi Type checking 2° parte Type checking 2° parte - Equivalenza di type expressions.
1 Meccanismi per la definizione di tipi di dato §la programmazione di applicazioni consiste in gran parte nella definizione di nuovi tipi di dato §un qualunque.
nome: sequenza di caratteri usata per denotare un oggetto
Type int_stack = struct { int top; int P[100]; } int_stack creapila() { int_stack s = new int_stack; s.top = 0; return s; } int_stack push(int_stack s,
mosaic manipola oggetti primitivi (ruota e unisci) regole:
Type int_stack = struct { int top; int P[100]; } int_stack creapila() { int_stack s = new int_stack; s.top = 0; return s; } int_stack push(int_stack s,
Puntatori - Cenni Nicola Fanizzi Corso di Programmazione C.d.L. in Informatica DIB - Università degli Studi di Bari.
Tipo di dato: collezione di valori omogenei ed effettivamente presentati, dotata di un insieme di operazioni che li manipolano – aiutano lorganizzazione.
Fondamenti di Informatica1 Linguaggi Classificati rispetto alle caratteristiche principali: –potere espressivo che influenza lo stile di programmazione.
Fondamenti di Informatica1 Realizzazione software Due fasi: 1. Specifica dell'algoritmo 1.a Definizione dei dati 1.b Definizione della modalità della loro.
AN FI Un denominatoe comune Comandi u notazioni che esprimono azioni che, una volta eseguite, comportano una modifica permanente dello stato interno.
AN FI Un denominatoe comune Linguaggi di programmazione Un denominatore comune.
AN FI Un denominatoe comune Lo stile funzionale Concetti fondamentali.
Ereditarietà e Polimorfismo
Macchine astratte, linguaggi, interpretazione, compilazione
Implementazione di un linguaggio ad alto livello (con riferimento a Java)
Enumerazioni e Classi 1. Enumerazioni Permettono di definire nuovi tipi che consistono in un insieme di valori costanti (ognuno con un nome) – Migliorano.
Sintassi base e struttura di un programma
Fopndamenti di programmazione. 2 La classe String Una stringa è una sequenza di caratteri La classe String è utilizzata per memorizzare caratteri La classe.
1 Tecniche per il passaggio dei parametri. 2 Contenuti ¥la tecnica base (nei vari paradigmi) ¥ passaggio per costante, per riferimento, di funzioni, procedure.
1 Implementazione di (ambiente e) memoria nel linguaggio imperativo.
Esercitazione su Vector. Permette di definire collezioni di dati generiche, che sono in grado di memorizzare elementi di ogni sottotipo di Object Definito.
Università di Torino – Facoltà di Scienze MFN Corso di Studi in Informatica Programmazione I - corso B a.a prof. Viviana Bono Blocco 7 – Array.
Ugo de'Liguoro - Informatica 2 a.a. 03/04 Lez. 7 Tipi di dato e strutture dati Specifica e realizzazione di strutture informative come classi.
1 Tipi di Dato §descrittori, tipi, controllo e inferenza dei tipi §specifica (semantica) e implementazione di tipi di dato l implementazioni “sequenziali”
Algoritmi e Strutture Dati Strutture Dati Elementari.
1 Controllo di sequenza: espressioni e comandi. 2 Contenuti ¥espressioni pure (senza blocchi e funzioni) ¥ regola di valutazione, operazioni strette e.
OBJECT ORIENTED DATABASE introduzione. OGGETTO Ha due componenti:  stato: valore di alcune variabili (variabili di istanza)  comportamento: insieme.
1 Tipi di Dato §descrittori, tipi, controllo e inferenza dei tipi §specifica (semantica) e implementazione di tipi di dato l implementazioni “sequenziali”
1 Il linguaggio C Precisazioni sull’esperienza in laboratorio.
estensione (con piccole varianti) di quella in
Nucleo di Java: Struttura e Semantica Espressioni Assegnamento Controllo di sequenza Dichiarazioni.
1 Progettazione dettagliata di un Tipo di Dato Astratto: l’ambiente di metodi.
1 Semantica Operazionale di un frammento di Java: le regole di transizione estensione (con piccole varianti) di quella in FONDAMENTI DI PROGRAMMAZIONE.
Linguaggi di Programmazione
Elementi di semantica denotazionale ed operazionale
1 Le s-espressioni. 2  Sexpr 4 alberi binari (possibilmente “vuoti”) che hanno sulle foglie atomi (stringhe) 4 sono la struttura dati base del linguaggio.
LIP: 2 Maggio 2008 Classi Astratte. Cos’e’ una Classe Astratta una classe astratta e’ un particolare tipo di classe permette di fornire una implementazione.
1 Semantica Operazionale di un frammento di Java: lo stato estensione (con piccole varianti) di quella in Barbuti, Mancarella, Turini, Elementi di Semantica.
Sommario Oggetti immutabili e non Tipi Primitivi: String, Arrays.
1 Programmazione Funzionale: ML 1 implementazione del -calcolo tipato l definizione di nuovi tipi ricorsivi l i valori dei nuovi tipi sono termini, che.
1 Macchine astratte, linguaggi, interpretazione, compilazione.
1 Linguaggi: guardando la semantica §esistono un insieme di concetti semantici e di strutture di implementazione in termini dei quali si descrivono in.
LIP: 11 Maggio 2007 Classi Astratte. Cos’e’ una Classe Astratta una classe astratta e’ un particolare tipo di classe permette di fornire una implementazione.
Progetto Parte II OCAML.
1 Gestione dinamica della memoria a heap (nel linguaggio orientato ad oggetti)
1 Semantica Operazionale di un frammento di Java: intro estensione (con piccole varianti) di quella di FP | v |
13. Strutture dati dinamiche Ing. Simona Colucci Informatica - CDL in Ingegneria Industriale- A.A
1 MODULO STRUTTURE DATI FONDAMENTALI: Strutture dinamiche classe 4° INDUSTRIALE INFORMATICA Focus on.
Transcript della presentazione:

1 Tipi di dato modificabili §a livello semantico, riconduciamo la modificabilità alla nozione di variabile l lo stato “modificabile” corrispondente sarà in realtà modellato con il dominio store §per l’implementazione usiamo varie strutture dati modificabili come l’array

2 Pila modificabile: interfaccia # module type MPILA = sig type 'a stack val emptystack : int * 'a -> 'a stack val push : 'a * 'a stack -> unit val pop : 'a stack -> unit val top : 'a stack -> 'a val empty : 'a stack -> bool val lungh : 'a stack -> int val svuota : 'a stack -> unit val access : 'a stack * int -> 'a exception Emptystack exception Fullstack exception Wrongaccess end

3 Pila modificabile: semantica # module SemMPila: MPILA = struct type 'a stack = ('a SemPila.stack) ref exception Emptystack exception Fullstack exception Wrongaccess let emptystack (n, a) = ref(SemPila.emptystack(n, a) ) let lungh x = SemPila.lungh(!x) let push (a, p) = p := SemPila.push(a, !p) let pop x = x := SemPila.pop(!x) let top x = SemPila.top(!x) let empty x = SemPila.empty !x let rec svuota x = if empty(x) then () else (pop x; svuota x) let rec faccess (x, n) = if n = 0 then SemPila.top(x) else faccess(SemPila.pop(x), n-1) let access (x, n) = let nofpops = lungh(x) n in if nofpops < 0 then raise Wrongaccess else faccess(!x, nofpops) end

4 Pila modificabile: implementazione module ImpMPila: MPILA = struct type 'x stack = ('x array) * int ref exception Emptystack exception Fullstack exception Wrongaccess let emptystack(nm,(x: 'a)) = ((Array.create nm x, ref(-1)): 'a stack) let push(x,((s,n): 'x stack)) = if !n = (Array.length(s) - 1) then raise Fullstack else (Array.set s (!n +1) x; n := !n +1) let top(((s,n): 'x stack)) = if !n = -1 then raise Emptystack else Array.get s !n let pop(((s,n): 'x stack)) = if !n = -1 then raise Emptystack else n:= !n -1 let empty(((s,n): 'x stack)) = !n == -1 let lungh( (s,n): 'x stack) = !n let svuota (((s,n): 'x stack)) = n := -1 let access (((s,n): 'x stack), k) = (* if not(k > !n) then *) Array.get s k (* else raise Wrongaccess *) end

5 S-espressioni §la struttura dati fondamentale di LISP l alberi binari con atomi (stringhe) sulle foglie l modificabili §vedremo solo interfaccia e semantica l l’implementazione (a heap) simile a quella delle liste

6 S-espressione: interfaccia # module type SEXPR = sig type sexpr val nil : sexpr val cons : sexpr * sexpr -> sexpr val node : string -> sexpr val car : sexpr -> sexpr val cdr : sexpr -> sexpr val null : sexpr -> bool val atom : sexpr -> bool val leaf : sexpr -> string val rplaca: sexpr * sexpr -> unit val rplacd: sexpr * sexpr -> unit exception NotALeaf exception NotACons end

7 S-espressione: semantica # module SemSexpr: SEXPR = struct type sexpr = Nil| Cons of (sexpr ref) * (sexpr ref)| Node of string exception NotACons exception NotALeaf let nil = Nil let cons (x, y) = Cons(ref(x), ref(y)) let node s = Node s let car = function Cons(x,y) -> !x | _ -> raise NotACons let cdr = function Cons(x,y) -> !y | _ -> raise NotACons let leaf = function Node x -> x | _ -> raise NotALeaf let null = function Nil -> true | _ -> false let atom = function Cons(x,y) -> false | _ -> true let rplaca = function (Cons(x, y), z) -> x := z | _ -> raise NotACons let rplacd = function (Cons(x, y), z) -> y := z | _ -> raise NotACons end

8 Programmi come dati §la caratteristica fondamentale della macchina di Von Neumann l i programmi sono un particolare tipo di dato rappresentato nella memoria della macchina permette, in linea di principio, che, oltre all’interprete, un qualunque programma possa operare su di essi §possibile sempre in linguaggio macchina §possibile nei linguaggi ad alto livello l se la rappresentazione dei programmi è visibile nel linguaggio l e il linguaggio fornisce operazioni per manipolarla §di tutti i linguaggi che abbiamo nominato, gli unici che hanno questa caratteristica sono LISP e PROLOG l un programma LISP è rappresentato come S-espressione l un programma PROLOG è rappresentato da un insieme di termini

9 Metaprogrammazione §un metaprogramma è un programma che opera su altri programmi §esempi: interpreti, analizzatori, debuggers, ottimizzatori, compilatori, etc. §la metaprogrammazione è utile soprattutto per definire, nel linguaggio stesso, l strumenti di supporto allo sviluppo l estensioni del linguaggio §In alternativa: Higher Order offre espressività e corret- tezza maggiore (per estensioni del ling.)

10 Meccanismi per la definizione di tipi di dato §la programmazione di applicazioni consiste in gran parte nella definizione di “nuovi tipi di dato” §un qualunque tipo di dato può essere definito in qualunque linguaggio l anche in linguaggio macchina §gli aspetti importanti l quanto costa (esprimerlo)? l esiste il tipo (quanto è veramente usabile)? l il tipo è astratto?

11 Quanto costa? -1 §il costo della simulazione di un “nuovo tipo di dato” dipende dal repertorio di strutture dati primitive fornite dal linguaggio l in linguaggio macchina, le sequenze di celle di memoria l in FORTRAN e ALGOL’60, gli arrays l in PASCAL e C, le strutture allocate dinamicamente ed i puntatori l in LISP, le s-espressioni l in ML e Prolog, le liste ed i termini l in C ++ e Java, gli oggetti

12 Quanto costa? -2 §è utile poter disporre di 1. strutture dati statiche sequenziali, come gli arrays e i records 2. un meccanismo per creare strutture dinamiche tipo di dato dinamico (lista, termine, s-espressione) allocazione esplicita con puntatori (à la Pascal-C, oggetti)

13 Esiste il tipo? §anche se abbiamo realizzato un'implementazione delle liste (con heap, lista libera, etc.) in FORTRAN o ALGOL l non abbiamo veramente a disposizione il tipo §poichè i tipi non sono denotabili l non possiamo “dichiarare” oggetti di tipo lista §stessa situazione in LISP e Prolog §in PASCAL, ML, Java i tipi sono denotabili, anche se con meccanismi diversi l dichiarazioni di tipo l dichiarazioni di classe

14 Dichiarazioni di tipo type nometipo = espressione di tipo §il meccanismo di PASCAL, C ed ML §il potere espressivo dipende dai meccanismi forniti per costruire espressioni di tipo (costruttori di tipo) l PASCAL, C enumerazione record, record ricorsivo l ML enumerazione prodotto cartesiano iterazione somma funzioni ricorsione §ci possono essere tipi parametrici l in particolare, polimorfi (parametri di tipo tipo)

15 Dichiarazioni di classe §il meccanismo di C ++ e Java (anche OCAML) §il tipo è la classe l parametrico in OCAML l con relazioni di sottotipo §i valori del nuovo tipo (oggetti) sono creati con un’operazione di istanziazione della classe §la parte struttura dati degli oggetti è costituita da un insieme di variabili istanza (o fields) allocati sulla heap

16 Il tipo è astratto? §un tipo astratto è un insieme di valori l di cui non si conosce la rappresentazione (implementazione) l che possono essere manipolati solo con le operazioni associate §sono tipi astratti tutti i tipi primitivi forniti dal linguaggio l la loro rappresentazione effettiva non ci è nota e non è comunque accessibile se non con le operazioni primitive §per realizzare tipi di dato astratti servono l un meccanismo che permette di dare un nome al nuovo tipo (dichiarazione di tipo o di classe) l un meccanismo di “protezione” o information hiding che renda la rappresentazione visibile soltanto alle operazioni primitive variabili istanza private in una classe moduli e interfacce in C ed ML