-
Data: 2011-10-16 11:19:24
Temat: Re: lambda i clojures
Od: Piotr Chamera <p...@p...onet.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2011-10-16 12:09, Piotr Chamera pisze:
> Można np. napisać to
>
> >> (let ((licznik 0))
> >> (defun następny () (setf licznik (1+ licznik)))
> >> (defun poprzedni () (setf licznik (1- licznik))))
>
> tak:
>
> (defvar *licz*
> (let ((licznik 0))
> (list
> (lambda ()
> (setf licznik (1+ licznik)))
> (lambda ()
> (setf licznik (1- licznik))))))
>
> taka konstrukcja zwraca listę funkcji (którym nie nadano nazw)
>
> CL-USER> *licz*
> (#<COMPILED-LEXICAL-CLOSURE #xC9E7EC6> #<COMPILED-LEXICAL-CLOSURE
> #xC9E7E9E>)
>
> i korzystać z licznika tak:
>
> CL-USER> (funcall (first *licz*))
> 1
> CL-USER> (funcall (first *licz*))
> 2
> CL-USER> (funcall (second *licz*))
> 1
> CL-USER> (funcall (second *licz*))
> 0
Dodam może jeszcze, że w tym przykładzie możemy zrobić
coś takiego:
CL-USER> (setf (symbol-function 'następny) (first *licz*))
#<COMPILED-LEXICAL-CLOSURE #xC83E976>
CL-USER> (setf (symbol-function 'poprzedni) (second *licz*))
#<COMPILED-LEXICAL-CLOSURE #xC83E94E>
CL-USER> (następny)
1
CL-USER> (funcall (first *licz*))
2
CL-USER> (następny)
3
CL-USER> (funcall (first *licz*))
4
...
Wywołujemy teraz tę samą funkcję, ale raz przez nazwę,
a drugi raz uruchamiając obiekt przechowywany na liście.
Następne wpisy z tego wątku
- 16.10.11 12:24
- 16.10.11 12:52 Piotr Chamera
- 16.10.11 13:15
- 16.10.11 13:37 Edek
- 16.10.11 13:46 Piotr Chamera
- 16.10.11 14:17 Stachu 'Dozzie' K.
- 16.10.11 14:27
- 16.10.11 14:49 Piotr Chamera
- 16.10.11 15:26 bartekltg
- 16.10.11 16:22 Piotr Chamera
- 16.10.11 16:43 Bronek Kozicki
- 16.10.11 16:44 Bronek Kozicki
- 16.10.11 17:11
- 16.10.11 17:56 Piotr Chamera
- 16.10.11 20:19 Bronek Kozicki
Najnowsze wątki z tej grupy
- "Wuj dobra rada" z KDAB rozważa: Choosing the Right Programming Language for Your Embedded Linux Device
- Nowa ustawa o ochronie praw autorskich - opis problemu i szkic ustawy
- Alg. kompresji LZW
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
Najnowsze wątki
- 2025-03-31 Kraków => IT Expert (Network Systems area) <=
- 2025-03-31 Białystok => NMS System Administrator <=
- 2025-03-31 Częstochowa => Product Manager - Systemy infrastruktury teleinformaty
- 2025-03-31 Sąd/Sędzia odrzuca wniosek o 30d aresztu Ziobry i jedzie po PO-Komisji Sroki [i Ziobrze w GW wersji]
- 2025-03-31 Warszawa => Sales Executive / KAM <=
- 2025-03-31 Warszawa => International Freight Forwarder <=
- 2025-03-31 Re: Państewko prawka Rumunia czyli pokaz UE leworządności - lider unieważnionych wyborów niedopuszczony do powtórki
- 2025-03-31 Dęblin => JavaScript / Node / Fullstack Developer <=
- 2025-03-31 Re: Kompensacja mocy biernej przy 230VAC
- 2025-03-31 Re: Kompensacja mocy biernej przy 230VAC
- 2025-03-31 Wrocław => Senior Backend Developer <=
- 2025-03-31 Białystok => Generative AI Engineer <=
- 2025-03-31 China-Kraków => Key Account Manager IT <=
- 2025-03-31 Prawne ciekawostki: Ksiądz KRK wygrał ze swoim biskupem sprawę o "naruszenie dóbr osobistych" [SN oddalił kasacje]
- 2025-03-31 Podatek od "konta wspólnego"