common-lisp
Loop di base
Ricerca…
Sintassi
- (do ({var | (var [init-form [step-form]])} *) (end-test-form result-form *) dichiarazione * {tag | istruzione} *)
- (do * ({var | (var [init-form [step-form]])} *) (end-test-form result-form *) dichiarazione * {tag | istruzione} *)
- (dichiarazione dolist (var list-form [result-form]) * {tag | statement} *)
- (dotimes (var count-form [result-form]) dichiarazione * {tag | istruzione} *)
dotimes
dotimes
è una macro per l' dotimes
intera su una singola variabile da 0 al di sotto del valore di un parametro. Uno degli esempi semplici sarebbe:
CL-USER> (dotimes (i 5)
(print i))
0
1
2
3
4
NIL
Si noti che NIL
è il valore restituito, poiché non ne abbiamo fornito uno; la variabile inizia da 0 e in tutto il loop diventa valori da 0 a N-1. Dopo il ciclo, la variabile diventa N:
CL-USER> (dotimes (i 5 i))
5
CL-USER> (defun 0-to-n (n)
(let ((list ()))
(dotimes (i n (nreverse list))
(push i list))))
0-TO-N
CL-USER> (0-to-n 5)
(0 1 2 3 4)
DOLIST
dolist
è una macro in loop creata per scorrere facilmente gli elenchi. Uno degli usi più semplici sarebbe:
CL-USER> (dolist (item '(a b c d))
(print item))
A
B
C
D
NIL ; returned value is NIL
Si noti che poiché non abbiamo fornito il valore di ritorno, viene restituito NIL
(e A, B, C, D vengono stampati su *standard-output*
).
dolist
può anche restituire valori:
;;This may not be the most readable summing function.
(defun sum-list (list)
(let ((sum 0))
(dolist (var list sum)
(incf sum var))))
CL-USER> (sum-list (list 2 3 4))
9
Ciclo semplice
La macro del ciclo ha due forme: la forma "semplice" e la forma "estesa". La forma estesa è trattata in un altro argomento di documentazione, ma il ciclo semplice è utile per il ciclo di base.
Il semplice modulo di loop prende un numero di moduli e li ripete fino a quando il ciclo non viene terminato utilizzando return o qualche altra exit (ad es. Throw ).
(let ((x 0))
(loop
(print x)
(incf x)
(unless (< x 5)
(return))))
0
1
2
3
4
NIL