我正在尝试编写一个使用3个线程的程序并打印0,1,2,3,4,5,....等等。
线程1 - 打印0,3,6,9等等
线程2 - 打印1,4,7,10等
线程3 - 打印2,5,8,11等等
有人可以帮我写这个代码吗?
答案 0 :(得分:1)
一种可能的解决方案涉及消息队列。每个线程都有一个消息队列。
0
,然后将0
发送到消息队列2。线程3从消息队列3中读取值,将其递增,然后将新值发送到消息队列1
从这里开始,你应该推断出第一个线程1应该做什么。
答案 1 :(得分:0)
以下程序使用条件变量进行同步。如果需要修改或发现任何错误,请帮助我。
#include <pthread.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#define THREAD_LIMIT 3
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
int PRINT_MAX = 500;
pthread_cond_t cond[THREAD_LIMIT];// = PTHREAD_COND_INITIALIZER;
struct thread_arg
{
int index;
pthread_cond_t *waitCond;
pthread_cond_t *signalCond;
};
void* threadFun(void* pArg)
{
struct thread_arg *pThreadArg = (struct thread_arg *)pArg;
int i=pThreadArg->index, rValue;
for(;i< PRINT_MAX;i += THREAD_LIMIT)
{
rValue = pthread_mutex_lock(&mutex);
printf("thread index = %d value = %d \n",(pThreadArg->index+1), i);
rValue = pthread_cond_signal(pThreadArg->signalCond);
//wait for turn
while( pthread_cond_wait(pThreadArg->waitCond, &mutex) != 0 )
{}
rValue = pthread_mutex_unlock(&mutex);
}
rValue = pthread_cond_signal(pThreadArg->signalCond);
return NULL;
}
int main()
{
pthread_t ThreadId[THREAD_LIMIT];
struct thread_arg ThreadArg[THREAD_LIMIT];
for (int i =0; i< THREAD_LIMIT ; i++)
pthread_cond_init(&cond[i], NULL);
for (int i =0; i< THREAD_LIMIT ; i++)
{
ThreadArg[i].index = i;
ThreadArg[i].waitCond = &cond[i];
if (i == THREAD_LIMIT-1)
ThreadArg[i].signalCond = &cond[0];
else
ThreadArg[i].signalCond = &cond[i+1];
printf("starting Thread %d \n",i+1);
pthread_create(&ThreadId[i], NULL, &threadFun,(void*)&ThreadArg[i]);
usleep(500);
}
for (int i =0; i< THREAD_LIMIT ; i++)
pthread_join(ThreadId[i],NULL);
return 0;
}
答案 2 :(得分:0)
具有3个线程的多线程程序,使用条件变量和互斥锁打印数字序列。
什么是条件变量和互斥量以及何时使用它以及如何使用它? Console.SetOut
#include<iostream>
#include<thread>
#include<mutex>
#include<condition_variable>
using namespace std;
//Creating 3 condition variable to perform synchronization in 3 different functions using wait and notify function on condition variable
condition_variable cv1, cv2, cv3;
//creating mutex variable to lock and unlock the resource
mutex m1;
void function1()
{
//creating unique_lock on the mutex so that we don't have to take care whether mutex is unlocked or not, as mutex gets unlocked as soon as unique_lock is out of scope (using concept of RAII)
unique_lock<mutex> lock(m1);
for(int i=0; i<10; i+=3)
{
cout<<i<<endl;
//We notify function2 using notify_one function, once we are done printing values from function one and makes function1 in wait state by calling wait function
cv2.notify_one();
cv1.wait(lock);
}
}
void function2()
{
unique_lock<mutex> lock(m1);
for(int i=1; i<10; i+=3)
{
cout<<i<<endl;
//We notify function3 using notify_one function, once we are done printing values from function2 and makes function2 in wait state by calling wait function
cv3.notify_one();
cv2.wait(lock);
}
}
void function3()
{
unique_lock<mutex> lock(m1);
for(int i=2; i<10; i+=3)
{
cout<<i<<endl;
//We notify function1 using notify_one function, once we are done printing values from function3 and makes function3 in wait state by calling wait function
cv1.notify_one();
cv3.wait(lock);
}
}
int main()
{
//creating 3 threads (t1, t2 & t3) and associating functions with each thread
thread t1(function1);
thread t2(function2);
thread t3(function3);
t1.join();
t2.join();
t3.join();
return 0;
}
输出:
0
1
2
3
4
5
6
7
8
9
答案 3 :(得分:0)
这可能是更好的解决方案
#include<iostream>
#include<thread>
#include<mutex>
#include<condition_variable>
using namespace std;
#define MAX 10
condition_variable cv1, cv2, cv3;
mutex m1;
int i;
void function1()
{
while (i < MAX) {
unique_lock<mutex> lock(m1);
cv1.wait(lock);
cout << i << endl;
i++;
lock.unlock();
cv2.notify_one();
}
}
void function2()
{
while (i < MAX) {
unique_lock<mutex> lock(m1);
cv2.wait(lock);
cout << i << endl;
i++;
lock.unlock();
cv3.notify_one();
}
}
void function3()
{
while (i < MAX) {
unique_lock<mutex> lock(m1);
cv3.wait(lock);
cout << i << endl;
i++;
lock.unlock();
cv1.notify_one();
}
}
int main()
{
thread t3(function3);
thread t1(function1);
thread t2(function2);
cv1.notify_one();
t1.join();
t2.join();
t3.join();
getchar();
return 0;
}