我的任务是编写一个生产者/消费者程序,其中有多个消费者,每个消费者对应于其自己的共享数据结构,而生产者可以访问所有共享数据结构。无论如何,我遇到的问题是用自己的结构初始化每个消费者线程;这是通过每个线程获得自己唯一的数字来完成的。 IE,线程0将数字0作为参数传入,线程1获得数字1,等等。但是,我只能通过调用sleep来获取每个线程的唯一编号。
struct SharedData {
int isopen;
int refcount; // reference count: number of threads using this object
unsigned int front; // subscript of front of queue
unsigned int count; // number of chars in queue
unsigned int bufsize;
pthread_cond_t buffer_full;
pthread_cond_t buffer_empty;
pthread_mutex_t mtex;
fifo_t* queue;
sem_t empty_count;
sem_t full_count;
sem_t use_queue; // mutual exclusion
};
struct OverSharedData{
struct SharedData ** rep;
int rop;
};
int main(int argc, const char *argv[])
//Other Code
struct OverSharedData* remp = (struct OverSharedData*)malloc(sizeof(struct OverSharedData));
rennit(remp);
struct SharedData * d = *(remp->rep + 0);
//Other Code
for (z=0; z<consumerthreads; z++) {
remp->rop = z;
pthread_create((Consumer_Threads+z), 0, Consumer, remp);
usleep(100);
}
remp-&gt; rop是包含其特定数字的每个线程的不同参数。如果我像这样评论usleep
for (z=0; z<consumerthreads; z++) {
remp->rop = z;
pthread_create((Consumer_Threads+z), 0, Consumer, remp);
}
我明白了:进入消费者:2
进入消费者:2
进入消费者:2
我想要的时候: 进入消费者:0 进入消费者:1 进入消费者:2
消费者代码在这里:
void* Consumer(void *arg){
pthread_mutex_lock(&grill);
struct OverSharedData * de = (struct OverSharedData *)arg;
printf("Entered Consumer: %d\n", de->rop);
int numb = de->rop;
pthread_mutex_unlock(&grill);
//Rest of code not necessary
如何在不使用睡眠调用的情况下初始化这些线程
答案 0 :(得分:1)
如果您的结构是全局的,它将在创建Z线程之前得到更新。 IE浏览器。在第一个线程执行之前,变量remp->rop
将增加Z次。