Can any one guide me with example about Thread and ThreadPool what is difference between them? which is best to use…? what are the drawback on its
Share
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
Since a thread can only run once, you’d have to use a thread per task. However, creating and starting threads is somewhat expensive and can lead to a situation where too many threads are waiting for execution (don’t remember the exact name for this right now) – which further reduces performance.
A thread pool is – as the name suggests – a pool of worker threads which are always running. Those threads then normally take tasks from a list, execute them, then try to take the next task. If there’s no task, the thread will wait.
Using a thread pool has several advantages:
Edit: Here are some quite good articles on concurrency in general: Sutter’s Mill, look at the bottom for more links. Although they’re primarily written for C/C++ the general concepts are the same, since it also describes the interdependence between concurrency solutions and hardware. A good article to understand concurrency performance issues is this article on drdobbs.com.