zoukankan      html  css  js  c++  java
  • 实现死锁

    实现死锁
    #include<stdio.h>
    #include<stdlib.h>
    #include<pthread.h>
    #include<errno.h>
    #include<unistd.h>
    #include<string.h>

    pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;//初始化了一个MUTEX锁

    void *func1(void *arg)
    {
         pthread_mutex_lock(&mutex);//给mutex加锁,这是一条原子操作,不可能出现两个线程同时执行这个代码
         int *a = (int *) arg;
         printf("thread%d start ", *a);
         int i;
         for (i = 0; i < 10; i++)
         {
              printf("thread%d is running ", *a);
              sleep(1);
         }
         printf("thread%d end ", *a);
         pthread_mutex_unlock(&mutex);//给mutex解锁
         pthread_exit(NULL);
    }

    void *func2(void* arg)
    {
        pthread_t th = *(pthread_t*)arg;
        sleep(2);
        pthread_cancel(th);
    }

    int main(int arg, char * args[])
    {
         printf("process start ");
         pthread_t thr_d1, thr_d2;
         int i[2];
         i[0] = 1;
         i[1] = 2;
         pthread_create(&thr_d1, NULL, func1, &i[0]);
        sleep(1);
         pthread_create(&thr_d2, NULL, func1, &i[1]);
         //设置死锁产生
        pthread_t thr_d3;
        pthread_create(&thr_d3, NULL, func2, &thr_d1);
         pthread_join(thr_d1, NULL);
         pthread_join(thr_d2, NULL);
         printf("process end ");
         return 0;
    }





  • 相关阅读:
    CCCC L2-023. 图着色问题【set去重判不同种类个数/简单图论/判断两相邻点是否存在同色以及颜色个数】
    百练 04 简单的整数划分问题
    NYOJ90 整数划分(经典递归和dp)
    图遍历问题
    图着色问题
    Java 大数(整数+浮点数) 基本函数
    根据规律绘制图形(俗称蛇皮走位)
    KMP算法之我见
    CCCC L1-039. 古风排版【图形输出/循环控制行列/模拟/细节】
    HYSBZ 2818 Gcd【欧拉函数/莫比乌斯】
  • 原文地址:https://www.cnblogs.com/ZhangJinkun/p/4531246.html
Copyright © 2011-2022 走看看