限制pthreads中并发线程数的执行

时间:2011-07-11 20:49:45

标签: c multithreading pthreads

我对pthread世界很新。 我需要处理一个包含命令列表的文件,假设文件看起来像这样 -

Command1
Command2
Command3
.
.
CommandN

对于每个命令,我想创建一个线程。现在的问题是,如果有大量的命令,我将最终创建大量的线程,这是我想要避免的。所以,我想限制在任何给定时间点执行的线程数。假设这个数字是5。

有人可以建议如何实现这一目标吗?我正在使用code来学习 -

#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#define NUM_THREADS 4

void *BusyWork(void *t)
{
   int i;
   long tid;
   double result=0.0;
   tid = (long)t;
   printf("Thread %ld starting...\n",tid);
   for (i=0; i<1000000; i++)
   {
      result = result + sin(i) * tan(i);
   }
   printf("Thread %ld done. Result = %e\n",tid, result);
   pthread_exit((void*) t);
}

int main (int argc, char *argv[])
{
   pthread_t thread[NUM_THREADS];
   pthread_attr_t attr;
   int rc;
   long t;
   void *status;

   /* Initialize and set thread detached attribute */
   pthread_attr_init(&attr);
   pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);

   for(t=0; t<NUM_THREADS; t++) {
      printf("Main: creating thread %ld\n", t);
      rc = pthread_create(&thread[t], &attr, BusyWork, (void *)t); 
      if (rc) {
         printf("ERROR; return code from pthread_create() is %d\n", rc);
         exit(-1);
         }
      }

   /* Free attribute and wait for the other threads */
   pthread_attr_destroy(&attr);
   for(t=0; t<NUM_THREADS; t++) {
      rc = pthread_join(thread[t], &status);
      if (rc) {
         printf("ERROR; return code from pthread_join() is %d\n", rc);
         exit(-1);
         }
      printf("Main: completed join with thread %ld having a status of %ld\n",t,(long)status);
      }

printf("Main: program completed. Exiting.\n");
pthread_exit(NULL);
}

Boss / Worker线程模型有没有好的例子?

3 个答案:

答案 0 :(得分:3)

创建一个放置新作业的队列。创建5个主题。每个线程将选择一个作业并处理它,然后它将选择下一个作业。一旦队列为空,线程就可以退出,你可以执行thread_join。您需要同步队列(或数组)。

答案 1 :(得分:0)

main中初始化一个初始值为4的信号量。在BusyWork函数内,每个线程应在输入时等待信号量,然后在退出时发布。一旦加入了所有线程,就破坏信号量。

EDIT!忘了link

答案 2 :(得分:0)

看起来你正在寻找的是线程池的概念。 Wikipedia Page与实现此功能的文章有一些不错的链接。另外,在github上搜索“线程池”应该会给你一些很好的简单实现。