程序喵阿呆 2021-11-04 17:07 采纳率: 50%
浏览 14
已结题

多线程随机性死锁问题

代码如下,期望效果是四个线程按顺序循环打印0123,但是实际总是死锁,一个循环0123都打不完,实在是搞不懂为什么会死锁



```c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <pthread.h>

#define NUM 4
pthread_mutex_t mutex;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;

static int num = 0;

static int next(int i)
{
    if(i == 3)
        return 0;
    return i+1;
}

static void *handler(void *p)
{
    int i = *(int*)p;
    while(1)
    {
        while(num != i)
            pthread_cond_wait(&cond, &mutex);
        //printf("thread %d\n", i);
        pthread_mutex_lock(&mutex);
        printf("%d\n", num);
        //fflush(NULL);
        num = next(num);
        pthread_cond_broadcast(&cond);
        pthread_mutex_unlock(&mutex);
    }
    pthread_exit(p);
}

int main()
{

    int i = 0;
    pthread_t tid[NUM];
    void *ptr = NULL;
    
    pthread_mutex_init(&mutex, NULL);
    pthread_mutex_lock(&mutex);
    for(; i < NUM; i++)
    {
        int *num = malloc(sizeof(int));
        *num = i;
        if(pthread_create(tid+i, NULL, handler, (void*)num))
        {
            perror("pthread_create()");

            exit(-1);
        }
    }
    pthread_cond_broadcast(&cond);
    pthread_mutex_unlock(&mutex);

    //alarm(1);

    for(i = 0; i < NUM; i++)
    {
        pthread_join(tid[i], ptr);
        free(ptr);
    }
    
    exit(0);
}

```

  • 写回答

1条回答 默认 最新

  • 程序喵阿呆 2021-11-05 14:45
    关注

    明白原因了,应该在判断num之前加锁,而不应该在wai之后加锁,没有搞清楚pthread_cond_wait的使用方法

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月13日
  • 已采纳回答 11月5日
  • 创建了问题 11月4日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵