Il metodo Math.random()
restituisce un double casuale compreso
nell'intervallo [0, 1), incluso il valore 0 ed escluso il valore 1
Se v
è una variabile double
, è possibile assegnarle
un valore casuale attraverso l'assegnazione v = Math.random();
oppure usare Math.random()
all'interno di una espressione più
complessa
Ogni volta che verra chiamato il metodo Math.random()
sarà restituito,
con altissima probabilità, un valore differente.
double
compreso nell'intervallo [0, 100) (suggerimento: moltiplicare ...).System.out.printf(...)
Il metodo System.out.printf(...)
, introdotto nelle versioni più recenti del linguaggio Java,
permette di visualizzare valori numerici e stringhe utilizzando un numero prefissato di caratteri, o di intervenire sul numero di decimali o sulla presenza dei separatori per le migliaia.
In tal modo si risolvono semplicemente alcuni inconvenienti di allineamento, come ad esempio nella stampa della sequenza seguente:
1 2 4 8 16 32 64 128che vorremmo ottenere incolonnata come segue
1 2 4 8 16 32 64 128Per ottenere il risultato correttamente incolonnato dovremmo stampare ciascun valore intero utilizzando esattamente 4 spazi, ad esempio 3 spazi e una cifra, oppure due spazi e due cifre, oppure uno spazio e tre cifre. Un altro uso comune del metodo riguarda la limitazione del numero di cifre decimali quando si stampano valori
double
e float
, se si vuole visualizzare ad esempio 3.333invece di
3.3333333333333335
System.out.printf(...)
Il metodo System.out.printf(...)
può essere invocato con un numero variabile di parametri,
di cui il primo è una stringa di formato, e i successivi sono espressioni qualsiasi.
System.out.printf(stringa di formato, espressione, espressione, ..., espressione)
La stringa di formato è una stringa che contiene caratteri qualsiasi,
caratteri speciali come \n
per tornare a capo, ed eventuali specifiche di formato
%d
un valore numerico intero (tipi byte
, short
, int
e long
)%f
un valore numerico floating point (tipi float
e double
)%g
un valore numerico floating point in notazione scientifica (tipi float
e double
)%s
un valore di tipo stringa di caratteriper ogni specifica di formato presente nella stringa di formato deve esserci una espressione di tipo adeguato tra i parametri successivi.
System.out.printf(...)
La chiamata al metodo causa la visualizzazione della stringa di formato, nella quale la prima specifica di formato viene sostituita con il valore della prima espressione, la seconda specifica di formato viene sostituita con il valore della seconda espressione, la terza specifica di formato viene sostituita con il valore della terza espressione, e così via.
Ad esempio, se somma
è una variabile int
e media
è una variabile double
, la chiamata
System.out.printf("la somma vale %d e la media vale %f\n", somma, media);
causa la visualizzazione del testo seguente:
la somma vale XXXX e la media vale YYYY
dove XXXX e YYYY sono rispettivamente il contenuto delle variabili somma
e media
È possibile indicare il numero di caratteri da utilizzare per la visualizzazione di ciascun valore modificando come segue le specifiche di formato:
%Nd
dove N è un numero intero: verranno premessi spazi fino ad utilizzare un totale di N posizioni%X.Yf
dove X e Y sono numeri interi: verranno premessi spazi fino ad utilizzare un totale di X posizioni, di cui esattamente Y per le cifre a destra del punto decimaleAd esempio, se la variabile somma
contiene il valore 25 e la variabile media
contiene il valore 12.5, la chiamata
System.out.printf("la somma vale %5d e la media vale %6.2f\n", somma, media);
causa la visualizzazione del testo seguente:
la somma vale 25 e la media vale 12.50