Linux系统线程死锁实验报告

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验四 Linux系统线程死锁实验报告

关键问题:实例可能会发生死锁,要求修改实例,预防死锁发生

设计思路:采用破坏占有且等待条件预防死锁发生!其中采用“空手申请资源策略预防死锁,即每个进程仅在它不占有资源时才可以申请资源。一个进程可能需要申请并使用某些资源,在它申请另外附加资源前必须先释放当前分到的全部资源!

实现的关键代码:

#include

#include

#include

#include

#define Max 7

pthread_t E[Max];//从东方来的汽车。每辆汽车对应一个线程。

pthread_t W[Max];//从西方来的汽车

pthread_t S[Max];//从南方来的汽车

pthread_mutex_t s1;//线程互斥信号量,对应C路段

pthread_mutex_t s2; //线程互斥信号量,对应B路段

pthread_mutex_t s3; //线程互斥信号量,对应A路段

pthread_mutex_t s4; //线程互斥信号量,对应D路段

int i;

void *s(void *a1) //南边来的汽车的线程执行体

{

int serialNum=*((int*)a1);//取当前汽车序号

pthread_mutex_lock(&s1);

printf("S %d enter C\n",serialNum);

sleep(2);

pthread_mutex_unlock(&s1);

pthread_mutex_lock(&s2);

printf("S %d enter B\n",serialNum);

sleep(2);

pthread_mutex_unlock(&s2);

pthread_mutex_lock(&s3);

printf("S %d enter A\n",serialNum);

sleep(2);

printf("S %d leave A\n",serialNum);

printf("!!!S finished one\n");

sleep(2);

pthread_mutex_unlock(&s3);

}

void *e(void *a2) //东边来的汽车

{

int serialNum=*((int*)a2);

pthread_mutex_lock(&s2);

printf("E %d enter B\n",serialNum);

sleep(2);

pthread_mutex_unlock(&s2);

pthread_mutex_lock(&s3);

printf("E %d enter A\n",serialNum);

sleep(2);

pthread_mutex_unlock(&s3);

pthread_mutex_lock(&s4);

printf("E %d enter D\n",serialNum);

sleep(2);

printf("E %d leave D\n",serialNum);

printf("!!!E finished one \n");

sleep(2);

pthread_mutex_unlock(&s4);

}

void *w(void *a3) //西边来的汽车

{

int serialNum=*((int*)a3);

pthread_mutex_lock(&s4);

printf("W %d enter D\n",serialNum);

sleep(2);

pthread_mutex_unlock(&s4);

pthread_mutex_lock(&s1);

printf("W %d enter C\n",serialNum);

sleep(2);

printf("W %d leave C\n",serialNum);

printf("!!!W finished one \n");

sleep(2);

pthread_mutex_unlock(&s1);

}

int main(int argc,char *argv[])

{

int c;

printf("Please input the integer number,less than 7: ");//车流量 scanf("%d",&c);

if( c > Max )

{

printf("You enter the wrong number,try again.\n");

exit(1);

}

int i1 = pthread_mutex_init(&s1,NULL); //线程互斥信号量创建及初始化 if(i1 != 0)

{

printf("Create error.");

exit(1);

}

int i2 = pthread_mutex_init(&s2,NULL);

if(i2 != 0)

{

printf("Create error.");

exit(1);

}

int i3 = pthread_mutex_init(&s3,NULL);

if(i3 != 0)

{

printf("Create error.");

exit(1);

}

int i4 = pthread_mutex_init(&s4,NULL);

if(i4 != 0)

{

printf("Create error.");

exit(1);

}

for(i = 1;i <= c; i++)

{

int* iaddr=&i;//汽车序号

pthread_create(&W[i-1],NULL,(void *)w,(void *)iaddr);//创建线程 pthread_create(&E[i-1],NULL,(void *)e,(void *)iaddr);

pthread_create(&S[i-1],NULL,(void *)s,(void *)iaddr);

sleep(5);

}

for(i = 0; i < c; i++)

{

pthread_join(W[i],NULL);//当前线程等待W[i]线程终止

pthread_join(E[i],NULL);

pthread_join(S[i],NULL);

}

exit(0); //main进程结束

}

程序运行结果:

相关文档
最新文档