|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Jan 2005
Messaggi: 307
|
[LISP] Problema chiusure
ciao, sto scrivendo il progetto per un esame e mi sto davvero incasinando sulle chiusure ( che credevo di aver capito, ma sto incontrando alcuni problemi ).
In sintesi per il progetto ho una lista che contiene delle funzioni ( che, come sapete sono liste anch'esse ) ad ognuna di esse ci devo aggiungere un argomento ( in sintesi se una funzione è " (princ (+ x y) " gli devo poter aggiungere z ); questo mi serve per creare un piccolo linguaggio ad oggetti in lisp, in particolare nel caso in cui chiamo una funzione che contiene il riferimento all'oggetto stesso ( il this di java ). Avevo pensato di creare questo utilizzando due chiusure successive, ma non riesco proprio a venirne a capo. Il problema che sto incontrando è riassumibile nel seguente esempio. Costruisco la seguente funzione: (defun prova (x y z) (funcall (lambda (x y) (funcall (lambda (z) (+ x y z)) z)) x y)) in sintesi dovrei chiudere successivamente z e x y. Fin qui tutto ok dato che se do nel listener: (prova 1 2 3) ottengo 6 che è il risultato aspettato. Se invece definisco: (defun prova2 (x y z metodo) (funcall (lambda (x y) (funcall (eval (list 'lambda '(z) metodo)) z)) x y)) e do nel listener: (prova 1 2 3 '(+ x y z)) mi da errore dicendomi che le variabili x ed y sono unbound, però non riesco assolutamente a capire perchè........
|
|
|
|
|
|
#2 | ||
|
Senior Member
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
|
Quote:
puoi fare un esempio ? Nel tuo caso intendi dire che il comando sopra deve diventare cosa ? Codice:
(princ (+ x y) z) Codice:
(princ (+ x y z)) Quote:
Mi vien da dire che e' perche' quando fai tu costruisci la funzione con Codice:
(eval (list 'lambda '(z) metodo)) Perche' non raccogliere tutto in un'unica lambda ? Codice:
(defun prova3 (x y z metodo) (funcall (eval (list 'lambda '(x y z) metodo)) x y z))
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele |
||
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Jan 2005
Messaggi: 307
|
Si, hai ragione su tutto... infatti io pensavo le stesse cose che mi hai risposto, ma non riuscivo a capire come scrivere il progetto.
Dopo un po' di domande al prof. salta fuori che il progetto è talmente scritto male che in tre abbiamo capito tre cose diverse.... in sintesi quello che non capivo come scrivere, semplicemente, non si poteva scrivere ed infatti stavo cercando di arrampicarmi sugli specchi in tutti i modi. Insomma se avesse scritto nel progetto quello che ci ha detto, avrei completato il progetto in 2 giorni e non in 2 settimane..... va beh, almeno ho imparato un bel po' di cose durante la scrittura e la riscrittura del codice |
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Jul 2006
Città: Bergamo
Messaggi: 401
|
Mi ricorda il progetto che ho fatto in lisp l'anno scorso xD
Scusate l'ot :P
__________________
iMac 27" 5K |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 08:17.




















