[Tutor] Using Queue

bob gailer bgailer at gmail.com
Wed Apr 23 19:17:58 CEST 2008


Kent Johnson wrote:
> On Wed, Apr 23, 2008 at 9:46 AM, bob gailer <bgailer at gmail.com 
> <mailto:bgailer at gmail.com>> wrote:
>
>     Evey time someone recommends Queue I think "oh boy this will
>     really help me". Then I go to the Library Reference, read the
>     Queue docs and think "oh boy who can help me understand this".
>     Even the sample code is confusing.
>
>
> Can you say what is confusing about it?

"The Queue module implements a multi-producer, multi-consumer FIFO queue.

I understand producer, comsumer, FIFO.

I don't understand multi-

"It is especially useful in threads programming when information must be 
exchanged safely between multiple threads. "

I understand threads. I've written some (to me fairly sophisticated) 
programs using Threading and conditions.

I understand that threads might want to exchange information.

I guess that queue supports the exchange by receiving and releasing 
items. Is that true?

I don't know what "safely" means.

"The Queue class in this module implements all the required locking 
semantics." I have no idea what that means nor does any of the ensuing 
documentation explain.
> Do you have a specific use in mind?

I have an application that uses Threading. It is not a producer, 
consumer application, just a bunch of threads that are started at the 
same time. And they do not communicate with each other, just with the 
main thread. But that seems to be true of Queue also.
> Queue is used to facilitate communication between threads, so any 
> Queue example includes multiple threads.
>
>
Regarding the sample code:
I must add (by trial and error) at least these 3 lines to the main program:

from threading import *
from Queue import Queue
num_worker_threads = 3

Then it bombs:
File "J:\python\queue.py", line 17, in <module>
    for item in source():
NameError: name 'source' is not defined

No idea what source is supposed to be. A callable object? And where in 
this example are the producer threads?

-- 
Bob Gailer
919-636-4239 Chapel Hill, NC



More information about the Tutor mailing list