【Android如何添加Mutex锁?】

不管现实多么惨不忍睹,都要持之以恒地相信,这只是黎明前短暂的黑暗而已。不要惶恐眼前的难关迈不过去,不要担心此刻的付出没有回报,别再花时间等待天降好运。真诚做人,努力做事!你想要的,岁月都会给你。【Android如何添加Mutex锁?】,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

1,Mutex::AutoLock介绍

Mutex是互斥类,用于多线程访问同一个资源的时候,保证一次只有一个线程能访问该资源。
AutoLock类是定义在Mutex内部的一个类,用于解决lock和unlock必须必须一一对应的问题。unlock这句代码可能会忘记写,从而导致死锁。AutoLock充分利用了C++的构造和析构函数,来达到自动调用unlock函数的目的。
要理解Mutex:: Autolock 的前提,需要知道C++的栈对象,在方法执行完之后,方法弹栈,对象会自动被回收,然后析构函数会被调用。

2,Mutex::Autolock声明和实现:
#include <utils/Mutex.h>
android::Mutex mInterfaceLock;
android::Mutex::Autolock l(mInterfaceLock);

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;
};
注意事项:
  Autolock对象应该被定义为局部变量中的局部变量,最好作用域仅仅只覆盖要lock住的代码块。这样在生命周期结束时就自动的把资源锁解了,同时也不会导致锁住的区域过大。

3,AutoLock的用法很简单:
先定义一个Mutex,如 Mutex xlock。
在使用xlock的地方,定义一个AutoLock,如 Mutex::Autolock autoLock(xlock)。
由于C++对象的构造和析构函数都是自动被调用的,所以在AutoLock的生命周期内,xlock的lock和unlock也就自动被调用了,这样就省去了重复书写unlock的麻烦,而且lock和unlock的调用肯定是一一对应的,这样就绝对不会出错。
当Autolock构造时,主动调用内部成员变量mLock的lock()方法,而在析构时正好相反,调用它的unlock()方法释放锁。这样的话,假如一个Autolock对象是局部变量,则在生命周期结束时就自动的把资源锁解了

下面是个例子,此例子中在{}代码块里面定义Autolock的对象_l,它的生命周期只在{}内部,也就是说只对那个if语句体上锁:
//SurfaceFlinger.cpp
void SurfaceFlinger::onVSyncReceived(int type, nsecs_t timestamp) {
bool needsHwVsync = false;

{ // Scope for the lock
    Mutex::Autolock _l(mHWVsyncLock);
    if (type == 0 && mPrimaryHWVsyncEnabled) {
        needsHwVsync = mPrimaryDispSync.addResyncSample(timestamp);
    }
}

if (needsHwVsync) {
    enableHardwareVsync();
} else {
    disableHardwareVsync(false);
}

}
,4,关于Linux应用mutex的使用

互斥锁是通过锁的机制来实现线程间的同步问题。互斥锁的基本流程为:

int pthread_mutex_init(pthread_mutex_t * mutex , pthread_mutexattr_t * attr);

int pthread_mutex_destroy (pthread_mutex_t * mutex);

int pthread_mutex_lock (pthread_mutex_t * mutex );

int pthread_mutex_unlock (pthread_mutex_t * mutex );

int pthread_mutex_trylock (pthread_mutex_t * mutex );

说明:

pthread_mutex_trylock()函数进行加锁时,若此时已经被锁,则会返回EBUSY的错误码。

解锁前,互斥锁必须处于锁定状态;(1)必须由加锁的线程进行解锁。(2)当互斥锁使用完成后,必须进行清除。

#include <pthread.h>
pthread_mutex_t mutex;
pthread_mutex_init(&mutex, NULL);
pthread_mutex_lock(&mutex);
pthread_mutex_unlock(&mutex);

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/182029.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!