pthread_mutex_t mA;
pthread_mutex_t mB;
void* task1(void* arg){
while(1){
pthread_mutex_lock(&mA);
printf("火车B通过隧道\n");
sleep(3);
pthread_mutex_unlock(&mB);
}
}
int main(int argc, const char *argv[])
{
pthread_t id;
pthread_create(&id,NULL,task1,NULL);
pthread_detach(id);
pthread_mutex_init(&mA,NULL);
pthread_mutex_init(&mB,NULL);
pthread_mutex_lock(&mA);
while(1){
pthread_mutex_lock(&mB);
sleep(3) ;
printf("火车A通过隧道\n");
sleep(6);
pthread_mutex_unlock(&mA);
}
return 0;
}
1:有一个隧道,全长5公里,有2列火车,全长200米, 火车A时速 100公里每小时 火车B时速 50公里每小时 现在要求模拟火车反复通过隧道的场景(不可能2列火车都在隧道内运行)
2:1:有一个隧道,全长5公里,有3列火车,全长200米, 火车A时速 100公里每小时 火车B时速 50公里每小时 火车c时速 25公里每小时 现在要求 火车A先通过隧道,火车B再通过隧道,最后火车C通过隧道
#include <unistd.h>
pthread_mutex_t mA;
pthread_mutex_t mB;
pthread_mutex_t mC;
void* task1(void* arg){
while(1){
pthread_mutex_lock(&mA);
printf("火车B通过隧道\n");
sleep(8);
pthread_mutex_unlock(&mB);
}
}
void* task2(void* arg){
while(1){
pthread_mutex_lock(&mB);
printf("火车c通过隧道\n");
sleep(2);
pthread_mutex_unlock(&mC);
}
}
int main(int argc, const char *argv[])
{
pthread_t id;
pthread_t id1;
pthread_create(&id,NULL,task1,NULL);
pthread_create(&id,NULL,task2,NULL);
pthread_detach(id);
pthread_detach(id1);
pthread_mutex_init(&mA,NULL);
pthread_mutex_init(&mB,NULL);
pthread_mutex_init(&mC,NULL);
pthread_mutex_lock(&mA);
pthread_mutex_lock(&mB);
while(1){
pthread_mutex_lock(&mC);
sleep(2) ;
printf("火车A通过隧道\n");
sleep(4);
pthread_mutex_unlock(&mA);
}
return 0;
}