473,387 Members | 1,569 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,387 software developers and data experts.

Re: Question on threads

Jonathan Shao wrote:
On Fri, Apr 11, 2008 at 3:29 PM, Steve Holden <st***@holdenweb.com
<mailto:st***@holdenweb.com>wrote:

Jonathan Shao wrote:

Hi all,
I'm a beginner to Python, so please bear with me.
Is there a way of guarenteeing that all created threads in a
program are finished before the main program exits? I know that
using join() can guarentee this, but from the test scripts I've
run, it seems like join() also forces each individual thread to
terminate first before the next thread can finish. So if I
create like 20 threads in a for loop, and I join() each created
thread, then join() will in effect cause the threads to be
executed in serial rather than in parallel.
No it won't, as in fact there is no mechanism to force a thread to
terminate in Python. When you join() each created thread the main
thread will wait for each thread to finish. Supposing the
longest-lived thread finished first then all others will immediately
return from join().

The only requirement it is imposing is that all sub-threads must be
finished before the main thread terminates.

regards
Steve
--
Steve Holden +1 571 484 6266 +1 800 494 3119
Holden Web LLC http://www.holdenweb.com/

I guess I'm doing something wrong with join(). Here's a test script I
wrote up...

import threading
import time
class TestThread(threading.Thread):
def __init__(self, region):
self.region = region
threading.Thread.__init__(self)
def run(self):
for loop in range(10):
print "Region " + str(self.region) + " reporting: " + str(loop)
time.sleep(2)
for x in range(10):
thr = TestThread(x)
thr.start()
thr.join()
raw_input()
In this script thread 0 will finish first... Am I doing something wrong
with join()?
Yes - you are calling it before you have started ALL your threads,
thereby making hte main thread wait for the end of thread 1 before
starting the next. An impressive demonstration of thread
synchronization, but not quite what you want :-)

Try saving the threads in a list then joining them later, like this
(untested):

threads = []
for x in range(10):
thr = TestThread(x)
thr.start()
threads.append(thr)
# Now all are started, wait for all to finish
for thr in threads:
thr.join()

regards
Steve
--
Steve Holden +1 571 484 6266 +1 800 494 3119
Holden Web LLC http://www.holdenweb.com/
Jun 27 '08 #1
2 1256
On 2008-04-11, Steve Holden <st***@holdenweb.comwrote:
Yes - you are calling it before you have started ALL your
threads, thereby making hte main thread wait for the end of
thread 1 before starting the next. An impressive demonstration
of thread synchronization,
Well, that's one way to get rid of the need for the GIL...

--
Grant Edwards grante Yow! Where's th' DAFFY
at DUCK EXHIBIT??
visi.com
Jun 27 '08 #2
Steve Holden wrote:
Jonathan Shao wrote:
>On Fri, Apr 11, 2008 at 3:29 PM, Steve Holden <st***@holdenweb.com
<mailto:st***@holdenweb.com>wrote:

Jonathan Shao wrote:

Hi all,
I'm a beginner to Python, so please bear with me.
Is there a way of guarenteeing that all created threads in a
program are finished before the main program exits?
I guess I'm doing something wrong with join().
Didn't we answer this question just a few days ago?

John Nagle
Jun 27 '08 #3

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

3
by: Ronan Viernes | last post by:
Hi, I have created a python script (see below) to count the maximum number of threads per process (by starting new threads continuously until it breaks). ###### #testThread.py import...
0
by: Al Tobey | last post by:
I was building perl 5.8.2 on RedHat Enterprise Linux 3.0 (AS) today and noticed that it included in it's ccflags "-DTHREADS_HAVE_PIDS." I am building with -Dusethreads. With newer Linux...
6
by: m | last post by:
Hello, I have an application that processes thousands of files each day. The filenames and various related file information is retrieved, related filenames are associate and placed in a linked...
34
by: Kovan Akrei | last post by:
Hi, I would like to know how to reuse an object of a thread (if it is possible) in Csharp? I have the following program: using System; using System.Threading; using System.Collections; ...
3
by: bygandhi | last post by:
Hi - I am writing a service which will check a process and its threads for their state ( alive or dead ). The process has 5 .net managed threads created using thread.start and each have been...
10
by: [Yosi] | last post by:
I would like to know how threads behavior in .NET . When an application create 4 threads for example start all of them, the OS task manager will execute all 4 thread in deterministic order manes,...
6
by: RahimAsif | last post by:
Hi guys, I would like some advice on thread programming using C#. I am writing an application that communicates with a panel over ethernet, collects data and writes it to a file. The way the...
3
by: mjheitland | last post by:
Hi, I like to know how many threads are used by a Threading.Timer object. When I create a Threading.Timer object calling a short running method every 5 seconds I expected to have one additional...
10
by: Darian | last post by:
Is there a way to find all the thread names that are running in a project? For example, if I have 5 threads T1, T2, T3, T4, T5...and T2, T4, and T5 are running...I want to be able to know that...
4
by: tdahsu | last post by:
All, I'd appreciate any help. I've got a list of files in a directory, and I'd like to iterate through that list and process each one. Rather than do that serially, I was thinking I should...
0
by: taylorcarr | last post by:
A Canon printer is a smart device known for being advanced, efficient, and reliable. It is designed for home, office, and hybrid workspace use and can also be used for a variety of purposes. However,...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: ryjfgjl | last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.