Standard ML: differenze tra le versioni
Aggiunto riquadro sinottico con fonti alle specifiche ufficiali e sito di riferimento |
m →Collegamenti esterni: Bot: Aggiungo portale |
||
Riga 46: | Riga 46: | ||
* {{en}} [http://www.kingston.ac.uk/~ku07009/MLWorkshop/start.html ML Workshop], di Chris Reade |
* {{en}} [http://www.kingston.ac.uk/~ku07009/MLWorkshop/start.html ML Workshop], di Chris Reade |
||
* {{en}} [http://www.standardml.org/Basis/ The Standard ML Basis Library], manuale aggiornato della libreria standard di SML |
* {{en}} [http://www.standardml.org/Basis/ The Standard ML Basis Library], manuale aggiornato della libreria standard di SML |
||
{{Portale|informatica}} |
|||
[[Categoria:Linguaggi di programmazione]] |
[[Categoria:Linguaggi di programmazione]] |
Versione delle 15:11, 10 mag 2015
Stanrdard ML linguaggio di programmazione | |
---|---|
Autore | Robin Milner, Mads Tofte, Robert Harper, David MacQueen |
Data di origine | 1990 |
Utilizzo | generico |
Paradigmi | funzionale e imperativo |
Tipizzazione | forte, statica, implicita |
Specifiche di linguaggio | SML '90[1], SML '97[2]. |
Estensioni comuni | .sml |
Influenzato da | ML |
Ha influenzato | OCaml, Rust |
Implementazione di riferimento | |
Sito web | Standard ML Family Project |
In informatica, SML (Standard ML) è un linguaggio di programmazione derivato dall'ML.
L'ML originale era una serie di MetaLinguaggi ideati da Robin Milner (e dai suoi studenti) all'Università di Edimburgo per creare programmi che eseguissero la dimostrazione di teoremi (theorem provers). Questi metalinguaggi furono poi "standardizzati" per dare origine all'SML, di cui lo standard più recente risale al 1997 (The Definition of Standard ML - Revised[2]).
L'SML è un linguaggio funzionale, quindi avente la caratteristica di rendere facile ed efficiente la creazione e l'uso di funzioni specializzate. In questo, SML assomiglia al Lisp o allo Scheme. Come questi, SML ha molti dialetti oltre al linguaggio standard, tra i quali si distingue OCaml, che è object oriented, e CML, che è concurrent o parallelo. Altri elementi comuni a Lisp e Scheme sono la presenza del garbage collector e di date di strutture dinamiche che sono integrate col linguaggio, per esempio le liste.
Al contrario di Lisp e Scheme, SML ha un sistema di tipi che permette già al momento della compilazione la verifica che le funzioni siano usate su argomenti del tipo giusto. Inoltre, diversi dialetti di SML hanno sistemi per organizzare i programmi in moduli, con firme (signature), implementazioni (structure), e implementazioni configurabili (functors).
Note
- ^ (EN) The Definition of Standard ML, di Robin Milner, Mads Tofte e Robert Harper. 1990, The MIT Press, Cambridge, Massachusetts - London, England.
- ^ a b (EN) The Definition of Standard ML, Revised, di Robin Milner, Mads Tofte, Robert Harper e David MacQueen. 1997, The MIT Press, Cambridge, Massachusetts - London, England.
Voci correlate
Compilatori ed interpreti
- SML/NJ ([1])
- MLton ([2])
- Moscow ML ([3])
- Poly/ML ([4])
- MLj ([5])
- SML.NET ([6])
- ML Kit ([7])
- Hamlet ([8])
Collegamenti esterni
- (EN) Standard ML Family Project Sito di coordinamento, riferimento e archiviazione storica del linguaggio e delle sue implementazioni.
- (EN) A Gentle Introduction to ML, di Andrew Cumming
- (EN) Programming in Standard ML '97: An On-line Tutorial, di Stephen Gilmore
- (EN) Programming in Standard ML, di Robert Harper
- (EN) ML Workshop, di Chris Reade
- (EN) The Standard ML Basis Library, manuale aggiornato della libreria standard di SML