Android同步类:Mutex和Condition的使用方式

Metux类

Mutex是互斥类,多个线程访问同一个资源时,要确保他们的互斥。主要函数有
lock(),unlock(),trylock()


函数名作用
lock()当使用lock函数时,当前的线程就会lock住;如果有线程已经锁住,lock()则会等待直到成功为止,系统只允许有一个线程被lock住
unlock()该函数可以释放线程
trylock()该函数尝试去锁进程,通过返回值可以判断是否能lock住

以下是Mutex的源码

inline Mutex::Mutex(int type, const char* name) {
    if (type == SHARED) {
       //type如果是SHARED,则表明这个Mutex支持跨进程的线程同步。
        pthread_mutexattr_t attr;
        pthread_mutexattr_init(&attr);
        pthread_mutexattr_setpshared(&attr, PTHREAD_PROCESS_SHARED);
        pthread_mutex_init(&mMutex, &attr);
        pthread_mutexattr_destroy(&attr);
    } else {
        pthread_mutex_init(&mMutex, NULL);
    }
}
inline Mutex::~Mutex() {
    pthread_mutex_destroy(&mMutex);
}
inline status_t Mutex::lock() {
    return -pthread_mutex_lock(&mMutex);
}
inline void Mutex::unlock() {
    pthread_mutex_unlock(&mMutex);
}
inline status_t Mutex::tryLock() {
    return -pthread_mutex_trylock(&mMutex);
}

AutoLock类

AutoLock类是Mutex的一个内部类,是为了方便使用Mutex而产生的。
在Mutex中,lock和unlock是必须成对出现的,但是当代码很复杂时,则会出现遗漏的现象。
利用构造和析构函数的性质,可以方便地让lock和unlock成对出现。
当需要使用lock函数时,构造一个AutoLock类,线程结束后该类析构,则相当于unlock,这样避免了发生lock和unlock不匹配的情况。

以下是Autolock的源码

class Autolock {
    public:
        //构造的时候调用lock。
        inline Autolock(Mutex& mutex) : mLock(mutex)  { mLock.lock(); }
        inline Autolock(Mutex* mutex) : mLock(*mutex) { mLock.lock(); }
        //析构的时候调用unlock。
        inline ~Autolock() { mLock.unlock(); }
    private:
        Mutex& mLock;
    };

Condition类

线程B或者C在运行前,必须有一个A线程的初始化,即A是一个条件,Condition则是用在这样的一种场景中,并且Condition和Mutex是配合使用的,Condition的函数都必须放在Mutex的lock和unlock之间。


函数名作用
wait(Mutex& mutex)线程B和C等待事件
waitRelative(Mutex& mutex, nsecs_t reltime)线程B和C的超时等待,B和C可以指定等待时间,当超过这个时间,条件却还不满足,则退出等待。
signal()触发者A用来通知条件已经满足,但是B和C只有一个会被唤醒。
broadcast()触发者A用来通知条件已经满足,所有等待者都会被唤醒。(广播)

以下是Condition的源码

class Condition {
public:
    enum {
        PRIVATE = 0,
        SHARED = 1
    };


    Condition();
    Condition(int type);//如果type是SHARED,表示支持跨进程的条件同步
    ~Condition();

    status_t wait(Mutex& mutex);

    status_t waitRelative(Mutex& mutex, nsecs_t reltime);

    void signal();

    void broadcast();


private:
#if defined(HAVE_PTHREADS)
    pthread_cond_t mCond;
#else
    void*   mState;
#endif
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值