Threading example (revised)
Jeff Blaine
jblaine at shell2.shore.net
Mon Feb 14 23:35:27 EST 2000
Ripped straight from Aahz Maruch's post the other day and simplified
as more of a 'visual learning tool' demo. Added a few comments...
whatever...just posting in case someone finds this one more graspable
at a thread-beginner level like me.
#!/usr/local/bin/python
import time, threading, whrandom
class MyThread(threading.Thread):
""" Each thread picks a 'random' integer between 0 and 19 and reports
in once per second for that many seconds.
"""
def run(self):
iterations = whrandom.randint(0, 19)
for i in range(iterations):
print " ", self.getName(), "is reporting in"
time.sleep(1)
print self.getName(), "is DONE"
if __name__ == '__main__':
threadList = []
# Create 5 MyThread() threads
for i in range(5) :
thread = MyThread()
threadList.append(thread)
# Start all threads
for thread in threadList:
thread.start()
# As long as we have more than just the 'main' thread running, print out
# a status message
while threading.activeCount() > 1 :
print str(threading.activeCount()), "threads running including main"
time.sleep(1)
More information about the Python-list
mailing list