>
(defun hib (f1 f2)
(cons
(function
(lambda ()
(setq f2 (+ f1 (setq f1 f2))))
)
(function
(lambda ()
(list 88 f1 f2 99 ))
)
)
)
hib
> (setq hib1 (hib 1 1))
(#<function :lambda nil (setq f2 (+ f1 (setq f1 f2)))> .
#<function :lambda nil (list 88 f1 f2 99)>)
> (setq hib2 (hib 1 1))
(#<function :lambda nil (setq f2 (+ f1 (setq f1 f2)))> .
#<function :lambda nil (list 88 f1 f2 99)>)
> (funcall (car hib1))
2
> (funcall (car hib1))
3
> (funcall (cdr hib1))
(88 2 3 99)
> (funcall (car hib1))
5
> (funcall (cdr hib1))
(88 3 5 99)
> (funcall (car hib1))
8
> (funcall (cdr hib1))
(88 5 8 99)
> (funcall (car hib2))
2
> (funcall (cdr hib2))
(88 1 2 99)
> (funcall (cdr hib1))
(88 5 8 99)
> (funcall (car hib2))
3
> (funcall (cdr hib2))
(88 2 3 99)
なぜ(funcall (car hib1))
変わるf1
のf2
でしょう(cdr hib1)
か?
なぜ(funcall (car hib1))
変わらないf1
のf2
です(cdr hib2)
か?