死锁

作者: 焦迈奇 | 来源:发表于2018-05-03 14:44 被阅读0次
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <ctype.h>
#include <pthread.h>

#define MAX_THREAD 3 
unsigned long long main_counter, counter[MAX_THREAD];
void* thread_worker(void*);
pthread_mutex_t mutext = PTHREAD_MUTEX_INITIALIZER;
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
int main(int argc,char *argv[])
{
    int i, ch;
    int num[3];
    pthread_t pthread_id[MAX_THREAD] = {0},thid; 
    //int *arr;
    for (i=0; i<MAX_THREAD; i++)
    {

       /* arr=(int *)malloc(sizeof(int));
        *arr=i;*/
    num[i] = i;
        if(pthread_create(&thid,NULL,(void*)thread_worker,&num[i])==0)
    {        
            pthread_id[i]=thid;
    }
    else
    {
        printf("thread creater failed!\n");
    }
    }
    pthread_mutex_lock(&mutex);
    do
    {
        //char t;
        unsigned long long sum = 0; 
        for (i=0; i<MAX_THREAD; i++)
        {
            sum += counter[i];
            printf("%d %llu ",i, counter[i]);
        }
        printf("\n\n%llu\n%llu\n\n", main_counter, sum);
    }while ((ch = getchar()) != 'q');
    //return 0;
      pthread_mutex_unlock(&mutex);
        pthread_mutex_destroy(&mutex);
        pthread_mutex_destroy(&mutex);
        return 0;
    
}
void* thread_worker(void* p)
{
    int thread_num;
   thread_num=*(int*)p;

    for(;;)
    { 
      pthread_mutex_lock(&mutext);
    main_counter++;
     counter[thread_num]++; 
     //main_counter++;
    sleep(1); 
     pthread_mutex_unlock(&mutext);
    }
    return NULL;
}
#include <sys/types.h>
#include <unistd.h> 
#include <ctype.h>
#include <pthread.h> 
#define LOOP_TIMES 10000 
pthread_mutex_t mutex1 = PTHREAD_MUTEX_INITIALIZER;
pthread_mutex_t mutex2 = PTHREAD_MUTEX_INITIALIZER;
void* thread_worker(void*);
void critical_section(int thread_num, int i); 
void  main(void)
{ 
    int rtn, i; 
    pthread_t pthread_id = 0; 
    rtn = pthread_create(&pthread_id, NULL, thread_worker, NULL ); 
    if(rtn != 0)
    { 
        printf("pthread_create ERROR!\n"); 
        return -1; 

    } 
    for (i=0; i<LOOP_TIMES; i++)
    { 
        pthread_mutex_lock(&mutex1);
        pthread_mutex_lock(&mutex2); 
        critical_section(1, i); 
        pthread_mutex_unlock(&mutex2);
        pthread_mutex_unlock(&mutex1);

    } 
    pthread_mutex_destroy(&mutex1);
    pthread_mutex_destroy(&mutex2); 
        //return 0; 
} 
void* thread_worker(void* p)
{ 
    int i; 
    for (i=0; i<LOOP_TIMES; i++)
    { 
        pthread_mutex_lock(&mutex1);
        pthread_mutex_lock(&mutex2); 
         critical_section(2, i); 
        pthread_mutex_unlock(&mutex2);
        pthread_mutex_unlock(&mutex1);
    }
} 
void critical_section(int thread_num, int i)
{ 
    printf("Thread%d:%d\n", thread_num, i);
}```

相关文章

  • 死锁

    线程饥饿死锁 锁顺序死锁 动态锁顺序死锁通过锁顺序来避免死锁 避免死锁

  • 死锁

    第11章:死锁和进程通信 死锁概念 死锁处理方法 死锁预防(Deadlock Prevention) 死锁避免(D...

  • java多线程笔记

    产生死锁的四个必要条件 处理死锁的基本方法 死锁预防 死锁避免 死锁检测 死锁解除 https://blog.cs...

  • [现代操作系统]--死锁

    table of content 死锁定义 死锁建模-- 资源分配图 处理死锁鸵鸟算法检测并恢复死锁检测死锁恢复利...

  • Java-多线程(四)死锁

    死锁 死锁示例

  • Java死锁

    什么是死锁 死锁检测 产生死锁的四个必要条件 如何避免死锁 死锁 死锁,指两个或多个线程之间,由于互相持有对方需要...

  • java并发--java死锁

    本篇结构: 前言 什么是死锁 产生死锁的必要条件 死锁的代码示例 死锁排查 如何避免死锁 总结 一、前言 今天被问...

  • Java多线程之死锁(Deadlock)及死锁避免(Deadlo

    线程死锁(Thread Deadlock) 数据库死锁(Database Deadlocks) 死锁避免 (Dea...

  • JavaEE面试题总结 Day39 2018-12-29

    什么是线程死锁?死锁如何产生?如何避免线程死锁? 死锁的介绍: 线程死锁是指由于两个或者多个线程互相持有对方所需要...

  • Java并发之嵌套管程锁死(Nested Monitor Loc

    嵌套管程死锁是如何发生的 具体的嵌套管程死锁的例子 嵌套管程死锁 vs 死锁 嵌套管程锁死类似于死锁, 下面是一个...

网友评论

      本文标题:死锁

      本文链接:https://www.haomeiwen.com/subject/ixokrftx.html