linux - 锁的粒度问题

查看:140
本文介绍了linux - 锁的粒度问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

struct mg_context {
    char        *options[NUM_OPTIONS];    /* Configured opions    */
    pthread_mutex_t    opt_mutex[NUM_OPTIONS];    /* Option protector    */
    int        max_threads;    /* Maximum number of threads    */
    int        num_threads;    /* Number of threads        */
    int        num_idle;    /* Number of idle threads    */
    pthread_mutex_t    thr_mutex;    /* Protects (max|num)_threads    */
    pthread_cond_t    thr_cond;
    pthread_mutex_t    bind_mutex;    /* Protects bind operations    */
};

以上,每一个变量都有对应的锁,假设有一个线程获得了opt_mutex[0],然后需要对
options[0]这个字符串进行修改,然后又有一个线程需要修改max_threads,
那这个线程可以成功获得thr_mutex锁吗?如果能的话,它能立即就修改max_threads吗?

解决方案

可以阿,这个锁能不能获取到是 跟这个锁有没有人在用这个锁有关系 跟其它的锁没有关系。。。
只要你要获取的锁不依赖于其它的锁(依赖的话其它的锁可能有人在用),就没有问题。。

这篇关于linux - 锁的粒度问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆