In article <m2a9ihxf3a....@cochabamba.vanoostrum.org>,
 Piet van Oostrum <p...@vanoostrum.org> wrote:

> I usually say that a closure is a package, containing a function with
> some additional data it needs. The data usually is in the form of name
> bindings.

That's pretty close to the way I think about it.  The way it was 
originally described to me is, "A closure is a function bundled up with 
it's arguments".

To make a real-life analogy, let's say you're modeling a parking garage.  
I want to be able to walk up to the attendant and say, "Please bring my 
car around front at 5 O'Clock.  It's that one" (pointing to the slightly 
dented green Ford in spot 37).  So, you've got a class:

class DeliveryRequest:
   def __init__(self, spot, time):
      self.spot = spot
      self.time = time

Now, over the course of the day, the garage attendants shuffle cars 
around to make room and retrieve vehicles that packed in the back.  
Comes 5 O'Clock, what vehicle do you want the attendant to deliver to 
the front?  The one that was in spot 37 at the time you made the 
request, or the one that's in spot 37 at 5 O'Clock?

Unless you want somebody else's car (perhaps you'd like something better 
than a slightly dented Ford), you want the attendant to capture the 
current state of spot 37 and remember that until 5 O'Clock when it's 
time to go get the car, no matter where it happens to be right now.

That's a closure.
-- 
https://mail.python.org/mailman/listinfo/python-list

Reply via email to