我对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线程模型有没有好的例子?
答案 0 :(得分:3)
创建一个放置新作业的队列。创建5个主题。每个线程将选择一个作业并处理它,然后它将选择下一个作业。一旦队列为空,线程就可以退出,你可以执行thread_join。您需要同步队列(或数组)。
答案 1 :(得分:0)
在main
中初始化一个初始值为4的信号量。在BusyWork
函数内,每个线程应在输入时等待信号量,然后在退出时发布。一旦加入了所有线程,就破坏信号量。
EDIT!忘了link!
答案 2 :(得分:0)
看起来你正在寻找的是线程池的概念。 Wikipedia Page与实现此功能的文章有一些不错的链接。另外,在github上搜索“线程池”应该会给你一些很好的简单实现。