Java Modelling Language: differenze tra le versioni
Contenuto cancellato Contenuto aggiunto
ho rimosso il fatto che JML fosse disponibile solo per java 1.4.2, informazione senza fonti |
|||
(15 versioni intermedie di 12 utenti non mostrate) | |||
Riga 1:
'''Java Modelling Language''' ('''JML''') è un [[linguaggio di specifica]] che permette di definire astrazioni procedurali su un modello di [[Design by contract|programmazione per contratto]], effettuando dei controlli sui [[Parametro (programmazione)|parametri d'ingresso]] di un [[Metodo (programmazione)|metodo]] e sul suo valore di ritorno
Le specifiche vengono aggiunte
==Sintassi==
Le specifiche JML sono espresse nella forma
<
//@ <Specifica JML>
</syntaxhighlight>
oppure
<
/*@ <Specifica JML> @*/
</syntaxhighlight>
===Direttive===
Riga 20:
:definisce una post-condizione sul metodo che segue
;<code>signals</code>
:definisce una condizione in base alla quale deve essere lanciata una [[Gestione delle eccezioni in Java
;<code>assignable</code>
:definisce di quali campi è consentito l'assegnamento dal metodo che segue
Riga 31:
;<code>assert</code>
:definisce una asserzione JML.
;<code>spec_public</code>
:Dichiara una variabile pubblica protetta o privata per scopi di specifica.
===Espressioni===
Riga 38 ⟶ 40:
;<code>\old(<name>)</code>
:modificatore con cui riferirsi al valore della variabile <code><name></code> al momento del lancio nel metodo
;<code>(\forall <dominio>;<range_valori>;<condizione> )</code>
:il [[quantificatore universale (simbolo)|quantificatore universale]] su un range di valori in un certo dominio che rispettano una certa condizione.
;<code>(\exists <dominio>;<range_valori>;<condizione> )</code>
:il [[quantificatore esistenziale (simbolo)|quantificatore esistenziale]] su un range di valori in un certo dominio che rispettano una certa condizione.
;<code>a ==> b</code>
Riga 47 ⟶ 49:
:il costrutto logico <code>a</code> se e solo se <code>b</code>
Le annotazioni JML hanno inoltre accesso agli [[oggetto (informatica)|oggetti]] Java, oltre che ai metodi ed agli [[Operatore (informatica)|operatori]] degli oggetti. Questi sono combinati per fornire
<
public class BankingExample {
Riga 77 ⟶ 79:
public /*@ pure @*/ int getBalance() throws BankingException { ... }
}
</syntaxhighlight>
==Bibliografia==
Riga 84 ⟶ 86:
==Collegamenti esterni==
*
{{Portale|informatica}}
[[Categoria:
|