线程同步打印5个随机数

时间:2011-12-17 16:18:40

标签: c++ c pthreads

我被要求编写一个程序,该程序将有2个线程并打印5个随机整数,这样第一个线程将生成一个数字,第二个将打印它。然后第一个将生成第二个数字,第二个线程将使用互斥锁打印它...等。

我的代码现在执行一个周期。如何扩展它以使线程执行5次方法?

#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>

void* generate (void*);
void* print (void*);

pthread_mutex_t m;
int number = 5;
int genNumber;


int main()
{
    int i;
    srandom(getpid());
    pthread_t th[2];

    pthread_mutex_init(&m,NULL);

    pthread_create(&th[0],NULL,generate,NULL);
    pthread_create(&th[1],NULL,print, NULL);

    for (i = 0; i < 2; i++)
        pthread_join(th[i], NULL);

    pthread_mutex_destroy(&m);

    return 0;
}

void* generate(void* arg)
{
    pthread_mutex_lock(&m);
    genNumber = random() % 9;
    printf("Generated #1 \n");
    pthread_mutex_unlock(&m);
}

void* print(void* arg)
{
    pthread_mutex_lock(&m);
    printf("The number is %d " , genNumber);
    pthread_mutex_unlock(&m);
    pthread_exit(NULL);
}

4 个答案:

答案 0 :(得分:2)

使用condition variables同步两个线程。当线程完成其工作时,它会向另一个线程发出信号唤醒,然后进入休眠状态等待更多工作。所以像这样:

// Pseudocode
pthread_cond_t c1, c2;
pthread_mutex_t mutex;

// Thread 1 (producer):
for(int i = 0; i < 5; i++)
{
    lock(mutex);
    genNumber = random() % 9;
    signal(c2);
    wait(c1, mutex);
    unlock(mutex);
}

// Thread 2 (consumer):
for(int i = 0; i < 5; i++)
{
    lock(mutex);
    wait(c2, mutex);
    print("The number is %d\n", genNumber);
    signal(c1);
    unlock(mutex);
}

答案 1 :(得分:1)

#include<stdio.h>
#include<stdlib.h>
#include<pthread.h>
#include<unistd.h>
static int *generate(void *);
static int *print(void *);
pthread_mutex_t m; 
pthread_cond_t con;
int munmber=10;
int gennumber;

int main() {
    srandom(getpid());
    pthread_t th1,th2;
    pthread_mutex_init(&m,NULL);
    pthread_create(&th2,NULL,print,NULL);
    sleep(1);
    pthread_create(&th1,NULL,generate,NULL);
    pthread_join(th1,NULL);
    pthread_join(th2,NULL);
    pthread_mutex_destroy(&m);

   }

  static int *generate(void *arg) {
  int i;
    while(i<5) {
            pthread_mutex_lock(&m);
            gennumber=random()%8;
            printf("NUMMBER GENERATED.... \n");
            pthread_cond_signal(&cond);
            i++;
            pthread_mutex_unlock(&m);
            sleep(2);
            if(i==5)
              exit(1);
    }

    return 0;
   }
    static int *print(void *arg) {
    int i;
    while('a') {
            pthread_cond_wait(&cond,&m);
            printf("GENERATED NUMBER is %d\n",gennumber);
            i++;
            pthread_mutex_unlock(&m);


    }

    return 0;
 }

答案 2 :(得分:0)

这里的互斥是不够的。您将需要一个条件变量,以确保以正确的顺序打印数字。一些伪代码:

//producer thread:
for(int i = 0; i < 5; i++)
{
    number = random();
    signal the other thread with pthread_cond_signal
    wait for signal from the consumer
}

// consumer thread
for(int i = 0; i < 5; i++)
{
    wait for signal with pthread_cond_wait
    print number
    signal the producer to produce another number
}

答案 3 :(得分:0)

你可以这样做:

int* generated = null;

void generate() {
  int i = 0;
  while (i<5) {
    pthread_mutex_lock(&m);
    if (generated == null) {
      generated = malloc(int);
      *generated = random() % 9;
      printf("Generated #1 \n");
      ++i;
    }
    pthread_mutex_unlock(&m);
  }
  pthread_exit(NULL);
}

void print() {
  int i = 0;
  while (i<5) {
    pthread_mutex_lock(&m);
    if (generated != null) {
      printf("The number is %d " , generated);
      free(generated);
      generated=null;
    }
    pthread_mutex_unlock(&m);
  }
  pthread_exit(NULL);
}

实际上我是在没有编译器的情况下编写的,因此可能存在一些错误,但概念应该有效。