[Tutor] Using Queue
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
> 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?
919-636-4239 Chapel Hill, NC
More information about the Tutor